2012-04-23  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Refine the return values of p_dns_cached_resolve(), p_dns_resolve() and
	p_recursive_query() so that they distinguish between answers found in
	the cache and replies obtained by querying other servers.
	This, among other things, can be used to prevent data that was recently
	obtained from the cache needlessly being added back to the cache.

2012-04-22  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* configure.in
	On the Linux platform, check if we can compile and link with the
	-pthread flag instead of linking with -lpthread.

2012-04-21  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	When following the delegation chain trying to get an authoritative
	answer, pdnsd would answer with SERVFAIL if it failed to get a reply
	from the last server in the chain. Instead pdnsd will now use the last
	reply in the chain with RCode=0 that raised the AA or RA flag, if there
	is one.

2012-04-19  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	In report_cache_stat(), make copies of volatile data to get a
	consistent data set before making calculations with cache size and
	entry numbers.

2012-04-16  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/netdev.c
	If we can't open /proc/net/if_inet6 in is_local_addr() log a warning
	message.

2012-04-15  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	The code checking for duplicate IP addresses obtained from NS records
	in auth_ok() has been slightly optimized.

2012-04-12  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	When resolving nameservers obtained from NS records, allow pdnsd to use
	more than one IP address per nameserver.
	In rare cases, using just one IP address for each nameserver will cause
	unnecessary resolve failures if the address chosen for each nameserver
	happens to be unreachable while the other addresses would lead to
	successful resolution, as demonstrated by Yuri Vorobyev.

2012-03-16  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	When adding RR records one by one to a cache entry using add_cent_rr(),
	use the smallest ttl value in case of conflicting ttls.
	Code for local/nonlocal conflict resolution has been taken out of
	add_cent_rr_int() and put into add_cent_rr() and cr_check_add()
	which should be slightly more efficient.

2012-03-15  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Enforcing strict RFC 2181 compliance by rejecting all the answers
	with inconsistent ttl timestamps can cause undesirable resolve failures.
	I have tried to implement a more compromising solution, whereby
	inconsistent answers that should be normally rejected are still never
	cached, but are nevertheless used as intermediary or temporary results
	if all else fails.

2012-03-13  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Fixed a typo in rr_to_cache() that caused pdnsd to fail to compile when
	configured with the --enable-strict-rfc2181 option.
	Thanks to Gonzalo L. R. for reporting this problem.
	Also changed the return value of rr_to_cache() from a simple boolean to
	an RC code in order to properly distinguish between memory allocation
	errors and time-stamp inconsistencies.

2012-02-21  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	If we have used EDNS in a query and the remote server answered
	with rcode "format error", try again with the OPT pseudo-record
	removed from the additional section of the query.

	Also fixed a bug in p_exec_query() that caused pdnsd to behave
	as if every reply with a non-empty additional section contained
	an OPT record.

2012-02-15  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/helpers.c,src/helpers.h,src/icmp.c,
	  src/ipvers.h,src/main.c,src/netdev.c
	Introduced a new macro SEL_IPVER() to reduce some of the clutter in the
	code caused by having to support both IPv4 and IPv6.

2012-01-31  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* configure.in
	Add AM_PROG_CC_C_O line to configure.in to prevent automake warning.

2012-01-29  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	In report_cache_stat(), add the average number of bytes used per cache
	entry when reporting the cache status, as suggested by M. Galabant.

2012-01-28  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/dns_query.c
	Cleaned up the code a bit to avoid warning messages when
	compiling with '-Wall -Winline' flags.

2012-01-18  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c
	Set the default of the edns_query option to false.

2011-07-31  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	Use a slightly more sophisticated merge-sort algorithm in sort_rrl().

2011-05-09  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	In compose_answer(), also add an OPT pseudo-RR to the additional section
	of a NXDOMAIN reply when appropriate.

2011-05-08  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/cache.h,src/dns_query.c,src/status.c
	Make the dns_cent_t struct more compact by putting the fields that are
	only used for either non-existent or existent domains, but not both,
	into a union so that these fields can share memory.
	When saving the cache to file, only write the TTL and time-stamp for
	a whole domain when it is negatively cached.

2011-05-06  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/cache.h,src/dns_query.c
	At the request of Andrei Caraman, the TTL of a negatively cached domain
	is now adjusted in accordance with the min_ttl and max_ttl options, just
	as it is done for (negatively) cached records.
	Additional change to the TTL policy is that for negative records (and
	negative domains) the neg_ttl setting overrides min_ttl if
	neg_ttl < min_ttl.

2011-04-26  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c
	Fixed memory leak that can occur when the configuration file is reloaded
	and an error is encountered while parsing the definition of a TXT
	record.

2011-03-21  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/make_rr_types_h.pl,src/cache.h,src/cache.c,src/dns_answer.c
	Introduced arrays rrmuiterlist and rrcachiterlist to make iterating
	over all possible RR types in a cache entry in strict ascending order
	a little more efficient.

2011-03-09  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c,src/conf-parser.c,src/conf-keywords.h
	Implemented a new config option "outgoing_ip", which
	makes it possible to bind outgoing connections to
	a specific interface.

2011-02-21  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/netdev.c
	Fixed UDP socket descriptors leak in the implementation of
	is_local_addr() for the FreeBSD platform. Thanks to Ashish Shukla for
	reporting this bug.

2011-02-14  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	In purge_all_rrsets(), also free the rrext array if it has become empty after
	purging all the RR sets.

2011-02-04  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conff.h,src/conf-parser.c,src/conf-keywords.h,
	  src/dns_query.c,src/dns_query.h,src/servers.c
	Changed "edns_query" from a "global" option to a "server"
	configuration option.

2011-02-04  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conff.h,src/dns_query.c,src/dns_query.h,src/servers.c,
	  src/conf-parser.c
	The query uptest sometimes fails because some DNS servers are configured
	to ignore empty queries. The new config option "query_test_name" makes
	it possible to query for a specific name instead.

2011-02-01  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	When processing a reply from a remote name server which seems to delegate
	to other name servers, check if the names for which NS records have
	been supplied have locally defined NS records. If so, the local
	records will now override those supplied by the remote server.

2011-01-31  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c
	Added support for defining TXT records in the configuration file.

2011-01-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Do not cache additional records from a response that is rejected because
	it contains IP addresses in the reject list, even when the reply
	is processed as a NXDOMAIN reply.

2011-01-25  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c
	Modified the function scan_string() to allow back-slashed escape
	sequences in strings.

2011-01-21  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/dns_query.c,src/conff.h,src/conff.c,
	  src/conf-parser.c
	Added support for EDNS (Extension mechanisms for DNS).
	Currently this is only useful for allowing UDP message sizes
	to be larger than 512 bytes.

2011-01-20  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	To avoid frequent reallocs when composing a DNS reply message,
	grow the message buffer in multiples of a certain minimum chunk size.

2011-01-19  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns.c,src/dns.h,src/dns_answer.c
	Extended debugging info with DNS-message lengths and flags of incoming
	messages.

2011-01-17  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conff.h,src/conf-parser.c,src/dns_answer.c
	Made "ignore_cd" option obsolete. It is now effectively always on.

2010-12-27  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/cache.h,src/dns_answer.c,src/dns_query.c,
	  src/make_rr_types.pl,src/rr_types.in,src/rr_types.c
	The array of pointers to rr_set_t structs in the dns_cent_t struct
	contains mostly null pointers in practice, so is somewhat
	inefficient in storage usage. This problem is exacerbated if we add
	support for caching more RR-types. To ameliorate to the problem
	I have decided to split the array in two, with one part fixed in the
	dns_cent_t struct as before, and an extension part that will be
	separately allocated, if necessary. If the extension part is used only
	for very rarely cached types, in most cases the extension array will not
	need to be allocated thus hopefully saving memory overall.
	The lookup tables which are necessary to support the new cache entry
	structure are cumbersome to write by hand, so I have written a perl
	script to do this automatically. As an additional benefit, which RR
	types are cache-able is now configurable for each type separately via
	rr_types.in.

2010-03-14  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Using randomized source ports for outgoing queries in IPv6 mode failed
	with the warning "Out of ports in the range 1024-65535, dropping query!",
	because the pdnsd tried to bind to the fixed port for incoming queries,
	instead of the dynamically chosen port. This is a very old bug, but it
	has only become apparent since source port randomization has become the
	default.
	Thanks to Philip-Andr� Fillion, Phil Sutter, Radoslaw Szkodzinski and
	others for reporting this bug and sending patches.

2009-12-25  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/status.c,src/status.h,src/pdnsd-ctl/pdnsd-ctl.c
	Add a magic number to pdnsd-ctl command codes to guard against
	possible incompatibility between the pdnsd-ctl utility and the
	pdnsd server.

2009-10-18  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Make root-server discovery a little more fault tolerant, i.e. if some
	of the root-server names don't resolve don't necessarily reject the
	whole result.

2009-10-17  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/servers.c,src/dns_query.c,src/dns_query.h
	Implemented automatic root-server discovery, which can now be configured
	by setting "root_server=discover".

2009-06-14  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c,src/consts.c,src/consts.h,src/conf-parser.c
	Changed the default behaviour of the "neg_rrs_pol" option. The default
	used to be to only cache records negatively in case the AA (authoritive
	answer) bit in the reply was set. The new default is to also allow
	negative caching in case the reply has the RA (recursion available) bit
	set and the query had the RD (recursion desired) bit set.
	This gives the behaviour that is usually wanted in case "proxy_only=on"
	is set without having to set "neg_rrs_pol=on", which can be more
	problematic. The new default can be explicitly set using
	"neg_rrs_pol=default". The values "on","off" and "auth" are also
	still available.

2009-06-13  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conff.h,src/dns_answer.c,src/conf-parser.c,src/conf-keywords.h
	Included a patch contributed by Andreas Steinmetz that implements a new
	global configuration option "ignore_cd". pdnsd used to check that the CD
	bit in the DNS header of queries is zero and return the error code
	"format error" if it is not. However, considering the meaning of this
	bit today it appears to be harmless to ignore it, so the new "ignore_cd"
	is on by default. Setting "ignore_cd=off" gives the earlier strict
	behavior.
	Also renamed the the Z1, AU, Z2 bits to correspond with their modern names
	CD, AD, Z.

2008-12-19  Paul Rombouts  <p.a.rombouts@home.nl>

	* pdnsd-1.2.7/src/dns_query.c
	If pdnsd receives a SERVFAIL response with a non-empty answer section,
	use the information tentatively if no better response is available.
	The previous behaviour was to discard the reply completely, which could
	cause failure to resolve some names.
	Thanks to Rafal Wijata for providing an example involving PowerDNS servers
	replying with CNAME records.

2008-09-01  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	In p_dns_resolve(), try to reduce the burden on root servers further for
	names ending in "arpa".

2008-08-31  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	In p_exec_query(), if the reply from a remote name server is negative
	(either because the rcode is NXDOMAIN or because the answer section
	contains no records for the queried name), ignore the remaining records
	in the answer section (in particular do not add them to the cache).

2008-07-29  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/dns_query.c
	Made the default of the configuration option query_port_start equal to
	1024.  Also improved the algorithm used by pdnsd to select random source
	ports to ensure that each (free) port gets an equal chance of being
	selected.  This should guarantee random source ports in the range
	1024-65535, making pdnsd less vulnerable to some of the issues described
	in CERT VU#800113.
	The old situation, where pdnsd lets the kernel select the source ports,
	is still available by specifying query_port_start=none.

2008-07-25  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Fixed a dangling pointer bug in p_exec_query(), which could cause pdnsd
	to crash when processing a long reply with many entries in the answer
	section.

2008-05-12  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c,src/conff.c
	Added a recursive-depth counter to the read_config_file() and
	confparse() functions to prevent the possibility of infinite
	recursion when processing include files.
	In confparse(), warn when in a server section the root_server option is
	set in combination with policy=simple_only or policy=fqdn_only.

2008-05-10  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/ipvers.h
	Included a patch contributed by Georg Schwarz which selectively undoes
	a Debian patch contributed by Juliusz Chroboczek on platforms for which
	the IPV6_RECVPKTINFO macro is not defined (e.g. MacOS X).

2008-05-08  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/status.c,src/pdnsd-ctl/pdnsd-ctl.c
	The pdnsd-ctl add command can now also be used to define NS records.
	A wildcard record defined with this command now behaves the same way as
	one defined in the config file.

2008-05-07  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c,src/conf-keywords.h,src/conff.c
	Added the ability to process "include" sections in the configuration
	file.  This makes it possible to place local definitions in separate
	files and include them from the main configuration file.

2008-05-05  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conf-parser.c,src/status.c,src/pdnsd-ctl/pdnsd-ctl.c
	Implemented two new pdnsd-ctl commands, which make it easier to add
	definitions to the pdnsd cache at run time. "pdnsd-ctl include" is
	similar to "pdnsd-ctl config" but only processes configuration sections
	that effect the cache and disallows global and server sections.
	"pdnsd-ctl eval" directly parses its string arguments as if they were
	part of a configuration (include) file.

2007-09-15  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns.h,src/dns_answer.c,src/dns_query.c
	Changed the declarations of various packed structs, by moving the
	__attribute__((packed)) specifiers from the field level to the struct level.
	This was necessary to get the correct value for sizeof(rr_hdr_t) when
	compiling with gcc for the ARM architecture.
	Thanks to Dirk Armbrust for reporting the problem and supplying the solution.

2007-08-10  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Applied a Debian patch contributed by Juliusz Chroboczek which
	reportedly fixes a problem with pdnsd running in IPv6 mode
	(IPV6_RECVPKTINFO instead of IPV6_PKTINFO).

2007-08-04  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	When resolving a name recursively, pdnsd would stop querying further
	name servers as soon as it received a reply with the authority (aa) flag
	set. Unfortunately, it appears this flag is sometimes raised erroneously
	in replies. I have implemented a work-around that ignores the aa flag
	when there appears to be a clear delegation to a sub-domain.
	Thanks to Nico Erfurth for reporting this problem.

	It appears that pdnsd would also fail to consult servers in the authority
	section when configured with neg_rrs_pol=on. This has been fixed.

2007-08-01  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/pdnsd-ctl/pdnsd-ctl.c
	Made the matching of pdnsd-ctl command names and most of the arguments
	case-insensitive.

2007-07-22  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Instead of sharing the responsibility for freeing the answer buffer in
	case of an error amongst different functions, only free it in
	compose_answer().

	* configure.in, src/Makefile.am, src/test/Makefile.am
	Merged patch contributed by Pierre Habouzit to deal with CFLAGS the
	automake way (allowing packagers to override CFLAGS properly).

2007-07-21  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	For each target name in a SRV record in the answer section, add
	addresses to the additional section of the response, as is recommended
	by the RFCs.

2007-07-14  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/list.c,src/list.h
	Made modifications to the implementation of dynamic arrays, which
	should ensure proper alignment on all supported architectures.

2007-07-10  Paul Rombouts  <p.a.rombouts@home.nl>

	* Upgraded pdnsd's license to GPL version 3.

2007-07-08  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.h,src/dns_query.c
	The data field of the rr_bucket_t struct is now aligned such that
	it possible to use straightforward assignment to copy IP addresses,
	making memcpy unnecessary for this purpose.

2007-07-07  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	If pdnsd fails to connect to a name server using a IPv6 address, it will
	now retry the connection using a IPv4 address, if available. This allows
	pdnsd to recover from situations where IPv6 connectivity is temporarily
	unavailable, but IPv4 connectivity still functions.
	Thanks to Andreas Ferber for reporting this problem.

2007-07-04  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	I have reordered the arguments of the add_rr() and related
	functions to make them more consistent with each other.

2007-07-03  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/hash.c
	pdnsd will no longer immediately abort in add_dns_hash() if it fails
	to allocate memory for a new hash entry.

2007-07-01  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conff.h,src/consts.c,src/consts.h,
	  src/conf-parser.c,src/conf-keywords.h,src/dns_query.c
	Implemented the new "reject", "reject_policy" and "reject_recursively"
	options for the server section of the configuration file.

	* src/ipvers.h,src/conf-parser.c,src/dns.c,src/status.c,
	  src/pdnsd-ctl/pdnsd-ctl.c
	Allow local AAAA records to be defined even if pdnsd is compiled
	without --enable-ipv6, provided there is sufficient support in the
	C libraries and --disable-new-rrs was not used.

2007-06-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Previously, when the answer buffer was realloced in add_rr(), an
	extra 2 bytes used to be reserved, which are unnecessary, as far
	as I can tell. I have decided to do without these extra 2 bytes,
	which originate from Thomas Moestl's code. As compensation, I have
	added extra PDNSD_ASSERT() statements to check that the answer
	buffer does not overflow.

2007-06-27  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/status.c, src/pdnsd-ctl/pdnsd-ctl.c
	Extended the pdnsd-ctl 'add a' and 'add aaaa' commands to allow
	multiple IP addresses to be specified.

2007-06-25  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conff.h,src/conf-parser.c,src/conf-keywords.h,
	  src/dns_query.c
	Implemented a new option for the server section of the configuration
	file: randomize_servers.

	* src/servers.c
	Improved the debug messages in uptest().

2007-01-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/icmp.c
	Fixed up the code implementing the ping test in icmp.c,
	which was broken for 64-bit systems.
	Thanks to Michael Uleysky for reporting this bug.

2007-01-09  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	auth_ok() now returns 1 if the cache entry has the DF_NEGATIVE flag set,
	without providing a list of authoritative servers to continue querying.
	Otherwise if we receive a non-authoritative NXDOMAIN reply and pdnsd
	is configured with neg_domain_pol=on, pdnsd will continue to try to
	get an authoritative answer. The intention is that pdnsd
	stops querying as soon as it gets an "unknown domain" answer.

2006-04-29  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/main.c
	pdnsd would segfault if it tried to call log_message() (via the
	log_warn() and log_error() macros) before the FILE pointer to the debug
	output stream was properly initialized.
	Thanks to Thomas Cort for discovering this problem and suggesting a fix.

2006-04-09  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c,src/helpers.c,src/conff.h,src/conff.c
	I have included a patch contributed by Jan-Marek Glogowski, that
	implements the configuration option "use_nss". With use_nss=off pdnsd
	will avoid system functions that may use NSS (i.e. initgroups()), which
	may need DNS for LDAP lookups, which can lead to long timeouts and
	stalls if pdnsd itself is used for the DNS lookup.

2006-03-26  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Negative caching of RR sets is now also supported with lean_query=off.

2006-03-25  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c,src/conf-parser.c,src/main.c
	I have implemented a new query method: udp_tcp. With this method a UDP
	query is tried first and, if the UDP answer is truncated, the query is
	repeated using TCP. This is the behaviour that seems to be recommended
	by the DNS standards. However, pdnsd wil not discard the truncated
	answer if the TCP requery fails.

2006-03-24  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Previously, pdnsd would add at most one additional A (and AAA) record
	for each record in the answer and authority sections. At the request of
	Angel Marin, pdnsd will now add all A and AAA records it can find in the
	cache for each name that produces additional records.

2006-01-02  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	compose_answer() would leak memory if the query contained
	an unsupported QTYPE or QCLASS. This has now been fixed.

2005-12-27  Paul Rombouts  <p.a.rombouts@home.nl>

	* configure.in
	TCP-query support is now compiled in by default.
	It can still be disabled using the configure option
	--disable-tcp-queries.

2005-12-23  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Queries received from clients with non-empty answer, authority or
	additional sections are	now treated as malformed and rejected with
	rcode 1 (format error).

2005-11-06  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c
	Time intervals in the configuration files can now be expressed in
	seconds, minutes, hours, days and weeks, using the suffixes
	s,m,h,d,and w.

2005-10-14  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/consts.c
	In the pdnsd configuration file, true/false and yes/no are now accepted
	as synonyms for the constants on/off.

2005-08-24  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/helpers.c
	I have fixed a potential buffer overflow problem that could occur with
	the 'pdnsd-ctl dump' command.
	In case of the root domain, the function rhn2str() would write 2 bytes
	to the output buffer even if size==1. Theoretically (under pathological
	circumstances) this could have allowed the dbuf buffer in the function
	dump_cent() to overflow by one byte.

2005-08-21  Paul Rombouts  <p.a.rombouts@home.nl>

	* acconfig.h,src/cache.c,src/conff.c,src/conf-parser.c,src/dns.c,
	  src/dns_answer.c,src/dns_query.c,src/error.h,src/helpers.c,src/main.c,
	  status.c

	It appears the newer versions of gcc won't convert a pointer to char
	into a pointer to unsigned char and vice versa without complaining.
	The changes I have made should get rid of these distracting warning
	messages. Unfortunately I had to introduce casts in some cases,
	which reduces type safety :-(.

2005-08-16  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns.h
	Some changes were made to the endianess detection code to
	address problems on Mac OS X v10.4 Tiger.

2005-08-15  Paul Rombouts  <p.a.rombouts@home.nl>

	* configure.in
	Some changes where made to address the reported problems with the
	configure script on Mac OS X v10.4 Tiger.

2005-08-05  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/status.c,src/dns_answer.c
	The output of the 'pdnsd-ctl status' command now includes some
	statistics on the number of query threads.

2005-07-29  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/main.c
	It appears that sigwait() can return EINTR under certain conditions.
	This explains the problems reported by Sanjoy Mahajan with strace
	and ACPI S3 sleep, which both caused pdnsd to exit prematurely.
	The return value of sigwait() is now checked and sigwait() is retried
	if the return value is EINTR.

2005-07-04  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	It appears that some servers that do not support recursive queries
	answer with "query refused" instead of "not supported". The
	p_exec_query() function now takes that possibility into account.

2005-07-01  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	In the processing of queries, I will make a distinction between
	recoverable errors and non-recoverable ones (typically caused by out of
	memory conditions). In the case of non-recoverable errors, no attempt to
	query alternative name servers is made.

2005-06-26  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	In p_recursive_query(), as soon as one of the servers in the q list
	replied "no error" or "name error", only this reply was examined and
	the other servers in the q list were ignored. Joshua Coombs has brought
	to my attention that this strategy sometimes fails when this reply is not
	authoritative and doesn't contain any usable references to name servers
	in the authority section.
	I have modified p_recursive_query() to allow pdnsd to continue querying
	the remaining servers in the q list as long as we haven't received an
	authoritative answer or usable authority information. This will allow
	pdnsd to arrive at the correct answer in some cases where it would
	formerly fail.

2005-06-25  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/status.c
	The "pdnsd dump" command may now also be given an argument
	consisting of a name beginning with a dot. This will dump information
	about all names in the cache ending in the given name. An argument
	consisting of a name without a leading dot will only give information
	about the exact name, as it did before.

2005-06-24  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/servers.c,src/status.c
	All uptests are now conducted by the server status thread. If a retest
	is requested via a "pdnsd-ctl server", an existing server status thread
	is signaled or a new server status thread is spawned if the old one has
	exited. This has the effect that a "pdnsd-ctl server label retest"
	command will now return immediately without waiting for the tests to
	finish.

2005-06-20  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c,src/servers.c,src/servers.h
	At the request of Al-Junaid Walker I have added a new configuration
	option for the uptest interval. With "interval=ontimeout" the server is
	not tested at startup/reconfig, or at regular intervals, but only after
	a DNS query to a server times out. However, once a server is declared
	dead it is never considered again unless it is revived using a
	"pdnsd-ctl config" or "pdnsd-ctl server" command.

2005-06-19  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/servers.c,src/dns_query.c,src/icmp.c
	During an uptest the server configuration data is locked. Especially
	with ping or query uptests of unresponsive servers this means that the
	execution of "pdnsd-ctl config" or "pdnsd-ctl server" commands can be
	delayed for a long time (or even time out). I have made modifications
	that allow a "pdnsd-ctl config" or "pdnsd-ctl server" commands to
	interrupt pending uptests to allow these commands to proceed without
	delay in most cases.

	* src/thread.h
	Use the POSIX sigaction() instead of signal() to install signal handlers.

2005-06-08  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/dns_query.c
	I have defined a struct dns_msg_t that includes a message length field.
	In the case of sending a DNS message over TCP, we no longer need a
	separate write() call to send the message length. This prevents possible
	packet fragmentation.

2005-06-07  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	The query_method=tcp_udp option only used to work with cooperative name
	servers, i.e. servers that either send back a TCP reply or explicitly
	refuse the TCP connection request. This wasn't sufficiently satisfactory
	in practice, because some name servers are completely unresponsive to TCP
	connection requests. I have made modifications to allow pdnsd to try UDP
	queries in case TCP connections time out. When a short server timeout is
	combined with a global timeout that is at least twice as long, this may
	allow a query to a name server that only responds to UDP queries to
	succeed with query_method=tcp_udp.

2005-04-20  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/hash.c,src/conff.c,src/status.c,src/pdnsd-ctl/pdnsd-ctl.c
	The "pdnsd-ctl empty-cache" command now accepts additional arguments;
	these are interpreted as include/exclude names. During execution of the
	command the name of each cache entry is matched against the names in the
	include/exclude list. If the name ends in a name to be included, the
	cache entry is deleted, otherwise not.
	This feature was added at the request of Joshua Coombs.

2005-04-19  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c, src/hash.c
	pdnsd will now (temporarily) unlock the cache between emptying hash
	buckets, this should allow pdnsd to remain responsive while executing
	the "pdnsd-ctl empty-cache" command. However, this only applies to DNS
	queries; pdnsd will not accept any new pdnsd-ctl commands while a
	pdnsd-ctl command is still running.

2005-03-29  Paul Rombouts  <p.a.rombouts@home.nl>

	* configure.in, src/hash.h
	I have added a new configure option --with-hash-buckets=...
	This makes it possible to specify a different number of
	hash buckets without editing the source files.

2005-03-17  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/error.c
	When running in both daemon and debug mode, print warning and
	error messages to debug file as well as the syslog.

2005-03-15  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Only call pthread_setspecific() in debug mode, because
	pthread_getspecific() is also only used in debug mode.
	If pthread_setspecific() fails, treat this as a non-fatal error.

2005-03-10  Paul Rombouts  <p.a.rombouts@home.nl>

	* configure.in
	On Linux systems the configure script will now try to detect automatically
	whether the system implements the Native POSIX Thread Library, but
	the method is not necessarily foolproof.

	* src/dns.c
	Local PTR records generated for resolving numeric IPv6 addresses back into
	names, are now based on ip6.arpa instead of ip6.int, because the latter domain
	will be phased out eventually.

2005-03-06  Paul Rombouts  <p.a.rombouts@home.nl>

	* Makefile.am,src/cache.c
	Create an empty cache-file at install time and don't complain about empty
	cache files at start up.

2005-02-20  Paul Rombouts  <p.a.rombouts@home.nl>

	* acconfig.h,configure.in,src/conf-parser.c,src/conff.h,src/dns.h,
	  src/dns_answer.c,src/dns_query.c,src/error.h,src/helpers.h,src/icmp.c,
	  src/ipvers.h

	I have applied some changes to the code proposed by Rodney Brown to improve
	portability. In particular, pdnsd should now compile on the Darwin platform
	(Apple Mac OS X).
	To support some of these changes, the source package is now built with a
	slightly more modern version of autoconf (2.57) and automake (1.6.3).

2005-01-29  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns.c,src/dns_answer.c,src/dns_query.c

	I have added some extra debug code to make it easier to discover the
	reason that pdnsd considers a query or reply malformed (format error).

2005-01-12  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns.c,src/dns_answer.c,src/dns_query.c

	I have extended some debug code contributed by Kiyo Kelvin Lee to dump
	the data received by pdnsd in debug mode (queries from clients, replies
	from name servers). Because this will give very verbose debug output,
	I've arranged it so that this data dump only occurs if pdnsd has been
	configured and compiled with --with-debug=9 and pdnsd has been called
	with -v9.

	Additionally, in the case that pdnsd rejects a reply from a name server
	because it is not well formed, I have refined the debug messages to
	distinguish between format errors due to unexpected truncation and
	others kinds of format errors.

2004-10-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/rr_types.c
	I have included some changes proposed by Joseph Pecquet to address
	the compilation problems reported by FreeBSD users.

2004-10-18  Paul Rombouts  <p.a.rombouts@home.nl>

	* acconfig.h,configure.in,src/helpers.c,src/helpers.h,src/dns.h
	I have merged a patch for CYGWIN support by Kiyo Kelvin Lee into
	my version of the code.

2004-10-15  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	Invalidating local records with the pdnsd-ctl did not work the way the
	documentation described. An invalidated local record would be always be
	purged at the next lookup, thus invalidation would practically have the
	same effect as deletion. An invalidated local record is of no use at all and
	would occupy space until it is purged during a lookup (but not by purge_cache).
	The function invalidate_record() now behaves as the documentation describes, i.e.
	invalidation of local records has no effect.

2004-09-27  Paul Rombouts  <p.a.rombouts@home.nl>

	* doc/pdnsd.conf.5.in
	A new man page describing the format of the pdnsd config file has been
	added to the pdnsd package. I've used a customized Perl script to generate
	one automatically from the html documentation.

2004-09-14  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/hash.c
	The cache entries in a hash chain are now stored in order of increasing long hash
	value. The advantage is that if an name is looked up that is not present in the
	cache, this can be done by comparing with only half (on average) of the number
	of entries in the hash chain. Not a huge speed up, but still worth while, I think.
	Additionally, the number of hash computations for each add_cache() call has
	been halved.

2004-09-11  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	insert_rrl() will no longer add local records to the rr_l list, because
	purge_cache() ignores them anyway.

2004-09-08  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns.h,src/cache.c,src/dns_query.c,src/dns_answer.c,src/conf-parser.c
	I've started using GETINT16,GETINT32,PUTINT16,PUTINT32 macros, which are based
	on the NS_GET/NS_PUT macros that can be found in the BIND source, instead of memcpy
	for fetching and storing non-aligned integer data.

2004-09-08  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/status.c,src/pdnsd-ctl/pdnsd-ctl.c
	New pdnsd-ctl command: "pdnsd-ctl dump" will print information about all the
	entries contained in the cache.
	"pdnsd-ctl dump <name>" will only print entries belonging to <name>.
	The data fields of the more common rr-types will be printed in human readable
	form, the remaining ones in a hexadecimal representation.
	With thanks to Dan Jacobson for suggesting this feature.

2004-08-31  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c
	At the suggestion of Dan Tihelka, I have expanded to the server_ip= option
	to allow the name of an interface to be specified instead of an IP address.
	pdnsd will not bind to the interface name, but will lookup the address the
	interface has at start up, and listen on that address. If the address
	of the interface changes while pdnsd is running, pdnsd will not notice that.

2004-08-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.h,src/cache.c
	I've reversed the meaning of the CF_NOAUTH and renamed it CF_AUTH.
	I've also added a domain level flag DF_AUTH, which is used to
	mark cache entries obtained from authoritave replies in response to
	a query of type * (all)..

2004-08-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	I've changed the format of the cache file. A typical cache entry has empty
	sets for most RR types (even more if DNS_NEW_RRS is defined). In the old
	format, each empty RR set was represented by a zero byte.
	In the new format only non-empty sets are respresented, leading
	to a (modest) reduction is size.

2004-08-28  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c
	New option for "rr" sections in the config file: reverse=on/off.
	If you want a locally defined name to resolve to a numeric address and vice
	versa, you can now achieve this by setting reverse=on before defining the
	A record, making it unnecessary to define a seperate PTR record for the reverse
	resolving.

2004-08-20  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.h,src/cache.c,src/conf-parser.c,src/dns_query.c
	At the request of Daniel Black, I have added support for defining local wildcard records
	in pdnsd. The only type supported presently is records beginning with '*.'.

2004-08-10  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/hash.c,src/cache.c,src/dns_query.c,src/dns_answer.c
	Sampo Lehtinen has remarked that pdnsd sometimes failed to resolve classless
	reversed-delegated IP addresses, and that this has something to do with the fact
	that pdnsd did not accept '/' characters in domain names. After reading Sampo's
	and Thomas' remarks, and also rfc2317 and some of the rfc's referenced in rfc2317,
	I decided pdnsd should place no restrictions at all on the types of characters it
	allows in domain names, only on the lengths of the byte sequences.
	This led me to make some quite extensive internal changes to pdnsd. Among other
	things domain names are now stored in transport format (sequences of bytes preceded
	by length bytes) instead of C strings. This is also more efficient because there
	is no need any more to convert from one representation to the other, except when
	reading the config file, interacting with pdnsd-ctl or running in debug mode.
	Conversion between the two representations isn't always possible, though.
	For example, domain names in transport format might contain non-printable characters.
	These are now printed as escape sequences (three octal digits preceded by a back slash).
	Presently there are still restrictions on the characters in the domain names that can
	be defined in local records. I doubt this will ever be considered a problem.

2004-08-02  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	The code for handling NXT records was flawed. A response from a remote server
	containing NXT records (even well-formed ones) could cause pdnsd to crash.
	The code for handling NAPTR records contained incorrect PDNSD_ASSERT statements,
	which could cause pdnsd to abort unnecessarily.

2004-07-25  Paul A. Rombouts  <p.a.rombouts@home.nl>

	* src/list.h,src/list.c,src/dns.c,src/dns_query,src/dns_answer.c
	I've noticed that some of the (dynamic) arrays that pdnsd uses are quite sparse.
	Instead of using an array structure with elements that are large enough to contain
	the largest possible domain name, I've implemented a "list" data structure that
	is more compact. The elements of a list can only be accessed sequentially from
	beginning to end, but it allows more efficient memory use in case the names are
	significantly shorter that the maximum.

2004-07-22  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conf-parser.c
	I've expanded pdnsd's configuration options by adding support in pdnsd for reading
	/etc/resolv.conf style files. Instead of specifying IP addresses in a server section,
	the option "file=<filename>" can be used.
	The IP addresses in the lines beginning with "nameserver" will be added to
	the list of address for that section, the remaining lines will be ignored.
	To avoid the possibility that pdnsd will query itself, local addresses are skipped
	(unless pdnsd is configured to listen on a different port number).

2004-07-21  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.h,src/cache.c,src/dns_query.c,src/conf-parser.c
	New option for "server" sections in the config file: root_server=on/off.
	In case a server section contains only addresses of root servers, which
	usually only give the nameservers of top level domains in their reply,
	setting root_server=on will enable certain optimizations. This involves using
	cached information to reduce queries to the root servers, thus speeding up
	the resolving of new names. This option is also necessary to make the
	delegation_only option work in combination with root servers.

2004-07-16  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/status.c,src/pdnsd-ctl/pdnsd-ctl.c
	New pdnsd-ctl command: "pdnsd-ctl empty-cache" will make pdnsd delete its entire
	cache, freeing all entries. This is useful for debugging purposes, or in situations
	where you suspect that stale cache entries are causing you problems, but you are not
	sure which ones.

2004-07-11  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/dns_query.c
	I've removed the use of the function add_cache_rr_add(), which was used to
	add additional RR records to the cache one at a time. I've changed the code
	in dns_query.c such that additional (or off-topic) records are first collected
	in arrays of dns_cent_t structures, and then added to the cache using add_cache().
	With this approach only one function, viz. add_cache(), is used for adding
	new entries to the cache, which I believe leads to a cleaner programming
	interface. Added benefit is that query serial numbers are no longer
	necessary.

2004-07-10  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.h,src/cache.c,src/dns_query.c,src/dns_answer.c
	I've added two new field to the dns_cent_t struct, namely c_ns and c_soa.
	These will be used to remember references to NS and SOA records in the authority
	sections of replies from remote name servers.
	This information can be used by pdnsd to fill in the authority section of its
	own reply.

2004-06-25  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c,src/servers.c,src/consts.c
	I've added an new server availability test which can be selected with "uptest=query".
	This can be useful as an alternative to "uptest=ping" in case the remote server does not
	respond to ICMP_ECHO requests at all, which unfortunately is quite common these days.
	"uptest=query" causes pdnsd to send an empty query to remote nameservers. Any well-formed
	response (apart from SERVFAIL) within the timeout period will be interpreted as a sign that the
	server is "up".
	In a sense this new availability test can actually be considered more reliable than the
	other ones that pdnsd supports.
	With thanks to Juliusz Chroboczek for suggesting this feature.

2004-06-24  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/helpers.c
	Don't use getpwnam() while we are multi-threaded, because it returns a pointer to
	a statically allocated structure. I will use getpwnam_r() instead, which is thread
	safe. Unfortunately there seem to be some portability problems with getpwnam_r().
	For those platforms that lack getpwnam_r(), I will keep the old code with getpwnam()
	as an alternative.

2004-06-23  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/servers.c
	Check that the number of IP addresses in a server section is nonzero before
	testing servers for availability. Otherwise pdnsd could crash in debug mode.

2004-06-21  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/conff.c,src/conf-parser.c,src/status.c,src/pdnsd-ctl/pdnsd-ctl.c
	New pdnsd-ctl command: "pdnsd-ctl config" will make pdnsd re-load its configuration file.
	In most cases (but there are still some exceptions) this is preferable
	to restarting pdnsd after making changes to the configuration file.
	An important advantage is that there should be no perceptible interruption in the dns service
	when using the reload command.
	An alternative config file can be specified with "pdnsd-ctl config <filename>".

2004-05-31  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/dns_query.c,src/dns_query.h
	I've made an adjustment to p_recursive_query() and related functions, so that
	when pdnsd chases name servers in pursuit of authoritative records, it avoids
	all the name servers already queried for the same name in the recursive calling
	chain, not just the servers most recently used.
	Although the hops counter will already break any possible cycles, this will
	allow pdnsd to detect pathological cycles earlier and waste less resources.

	* src/cache.c
	In add_cache(), don't add empty entries to the cache. Empty cache entries
	waste memory and are more persistent than non-empty ones, because purge_cache()
	cannot get rid of them.

2004-05-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/dns_query.c,src/icmp.c,src/netdev.c
	I've removed the calls to getprotobyname() and used the constants IPPROTO_TCP
	and IPPROTO_UDP instead. First of all, it doesn't seem very efficient to call
	a function repeatedly to look up the same well-known protocol numbers.
	More importantly, getprotobyname() stores its results in a statically-allocated
	structure and thus cannot be considered thread safe. (getprotobyname_r()
	is thread safe, but is not portable.)

2004-05-27  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	I've noticed that when pdnsd is restarted shortly after it has answered a TCP
	query, it is often not able to bind to the TCP socket again, resulting in a
	disabled TCP server thread. The solution appears to be to set the SO_REUSEADDR
	socket option before binding the socket. This allows you to use the same port even
	if it is busy (in the TIME_WAIT state).
	I found the code for this in a patch file from an old Debian package.

2004-05-20  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	Joseph Pecquet has reported that version 1.1.11 does not compile under FreeBSD v4.x
	because the macro ENONET is undefined. I've bypassed the problem by surrounding
	the case line using this value with conditional preprocessor directives.

2004-05-08  Paul  Rombouts  <p.a.rombouts@home.nl>

	* src/rc/Slackware/rc.pdnsd
	I've included a Slackware start-up script contributed by Nikola Kotur.

2004-05-05  Paul Rombouts  <p.a.rombouts@home.nl>

	* doc/pdnsd.8
	I'm very grateful to Mahesh T. Pai for contributing a pdnsd man page,
	which was still missing up till now.

2004-04-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/servers.c,src/dns_query.c
	After considering some suggestions made by Juliusz Chroboczek I have made the
	following changes:

	- After receiving a reply from a remote server mark the server up and update the
	timestamp so that pdnsd doesn't bother testing this server for availability for a
	while.
	- After detecting an error with an send/recv call that indicates a server is
	unavailable, mark a server down so that pdnsd doesn't bother testing this server
	for a while.
	- After server timeouts, uptests are never performed by a query/answer thread,
	because this may delay the sending of an answer to the client. Instead the
	timestamp of a server that needs to be tested for availability is set to zero and
	a condition signal is sent to alert the server status thread, which will carry out
	the test. Unresponsive servers with uptest=ping will not be marked down
	immediately any more, but only after the ping test has definitely failed.

	* src/error.c,src/error.h
	I've moved most of the code previously contained in the DEBUG_MSG macro to a new
	function debug_msg().
	The DEBUG_MSG macro now simply expands to "if(debug_p) debug_msg();".
	This should make the executable a little smaller, and be just as fast when
	debugging is off. The DEBUG_MSG macro still expands to nothing if pdnsd is built
	without debugging support.

2004-04-28  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.h,src/dns_query.c
	I've tried to simplify the finite state machine used for processing parallel
	queries, by merging the "state" and "nstate" variables used by p_exec_query() and
	p_query_sm() resp. into one "state" variable.
	By introducing an extra field "iolen" to keep track of the number of bytes read
	from or written to a socket, I could also reduce the number of states for TCP
	queries. The new code has the additional advantage that it can handle situations
	that require multiple read() calls to receive a response.

2004-04-14  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	I've added an extra check comparing the number if poll/select events actually
	handled to the return value of poll/select. This should reduce the chance that
	pdnsd will get caught in a busy spin due to unknown remaining bugs. An error
	message is logged and an error code is returned when this comparison fails.

2004-04-13  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.h,src/dns_query.c
	I got rid of the event field in the query_stat_t struct.
	I think it is redundant, because its value can be quite simply derived from
	the nstate field.

2004-04-12  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	I appears there was flaw in the code for handling a "Not Implemented" response
	from a remote server with the RA (recursion available) bit equal to zero. This
	could cause pdnsd to get into a busy spin. I traced the flaw back to Thomas
	Moestl's code, so it must be in all the versions of pdnsd I know of. In previous
	versions of pdnsd the busy spin would eventually time out. Due to some recent
	changes the loop would no longer time out, making the bug more noticeable.
	With thanks to Nicolas George for reporting the bug.

	I also discovered a closely related flaw that would cause pdnsd to poll() closed
	file descriptors. It usually works out OK in practice, but it is definitively not
	the correct way to do it.

	Additionally, I discovered some opportunities to save memory, e.g. by replacing
	the nsname buffer in the query_stat_t struct by a pointer to an already existing
	copy of a name.

2004-04-10  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	Nicolas George remarked that he thought it was strange that subdomains of domains
	negated with "neg" sections in the config file were not also negated. I thought that
	he had a point, and I've implemented a change so that negating example.com will
	now also negate www.example.com, xxx.adserver.example.com, etc.

2004-04-09  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/error.c,src/error.h
	I noticed that the code for the log_warn() and log_error() functions was almost
	identical, even to the point that log_warn() called syslog() with LOG_ERR
	priority. I've merged these two functions into one log_message() function.

2004-04-08  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/main.c,src/conf-parser.c
	The -4 and -6 command-line options should now work as advertised.
	This wasn't entirely trivial. The rule is that options on the command line
	override those in the configuration file. The easiest way to implement this is to
	process the command-line options after reading the configuration file. But this
	doesn't work for the -4 and -6 options, because the run_ipv4 flag determines how
	IP addresses in the config file are parsed. I've inserted some extra tests and
	warning messages that will hopefully make this setting nearly foolproof.

	I've added two new command-line options, "-a" and "-i <prefix>".
	With the -a flag pdnsd will try to detect automatically if IPv6 support is
	available on a system, and fall back to IPv4 if not. The -a flag can be used
	instead of -4 or -6.

	In IPv6 mode, pdnsd will now automatically convert IPv4 addresses to IPv6-mapped
	addresses. The -i option can be used to specify a prefix for this mapping. The
	default is ::ffff.0.0.0.0
	There is also a corresponding ipv4_6_prefix= option for the config file.

	In IPv4 mode, if IPv6 support is compiled in, pdnsd will now skip IPv6 addresses
	in the config file (except for the server_ip and ping_ip options) with a warning
	message. This allows you to have mixed sets of IPv4 and IPv6 address in the same
	config file, although in IPv4 mode some server sections may become inactive.

	With thanks to Juliusz Chroboczek for suggesting these changes.

2004-04-07  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	I've changed some of the cache-flag definitions to make debugging a little simpler.
	Unfortunately, this makes the cache files of previous pdnsd versions incompatible
	with the new one. I've introduced a cache version identifier to be added at the
	beginning of each cache file. This enables pdnsd to recognize and discard
	incompatible cache files.

2004-04-05  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.h,src/cache.c
	I've changed the way CACHE_LAT (cache latency, normally 120 secs) is used to
	determine whether a cache entry has timed out. Instead of simply adding it to the
	ttl (time to live), I use CACHE_LAT if the ttl is less then CACHE_LAT, else the
	ttl itself, making CACHE_LAT the minimum ammount of time a cache entry stays in
	the cache.

2004-04-02  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	I've introduced a global timeout parameter. This is the minimum period of time
	pdnsd will wait after sending the first query to a remote server before giving
	up without having received a reply.
	The timeout options in the configuration file are now only minimum timeout intervals.
	Setting the global timeout option makes it possible to specify quite short timeout
	intervals in the server sections. This will have the effect that pdnsd will start
	querying additional servers fairly quickly if the first servers are slow to respond
	(but will still continue to listen for responses from the first ones).
	This may allow pdnsd to get an answer more quickly in certain situations.

	* src/dns_query.c
	When receiving a NXDOMAIN (unknown domain) response from a remote name server,
	I think it is still useful to process the authority and additional sections,
	so that pdnsd can possibly add a SOA record to its own response.

2004-04-01  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_query.c
	In p_recursive_query(), I've slightly changed the way pdnsd does parallel
	queries. Active queries or not canceled until we have received a useful response
	from a remote name server, or all the queries have failed or timed out.
	Thus the par_queries parameter is no longer the maximum number of parallel
	queries, but rather the increment with which the number of parallel queries is
	increased when the previous set has timed out.
	In the worst case all the servers in the list of available servers will be queried
	simultaneously. We may be wasting more system resources this way, but the advantage
	is that we have a greater chance of catching a reply.
	After all, if we wait longer anyway, why not for more servers.

2004-03-31  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	I've noticed that in compose_answer() that while adding the name in the query
	section it was not passed through compress_name(). While it is true that the
	first name occurrence cannot be compressed, it is still sensible to process the
	query name with compress_name() so that the offset can be stored and provide
	additional opportunities for future compressions.
	I've tested this with dig and the responses of pdnsd are now usually a little
	smaller	in size or can hold more information within the 512 byte limit.

2004-03-30  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	I've noticed that pdnsd stored rr records (of the same type) in reverse order
	in the cache.
	Although I don't see anything inherently wrong with that, I think it's neater to
	store them in the order they are processed.

2004-03-29  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	I've rearranged the order of the arguments of some of the functions in cache.c
	to obtain a more consistent calling interface.

	* src/dns_answer.c
	I've noticed that pdnsd would only add NS records to an authority section if it could
	find such records matching the queried name (or the last CNAME in the answer) exactly.
	However, I understand that a server should try to give NS records as close as possible
	to the target name in the naming hierarchy.
	I also understand that if a domain name is reported as nonexisting, or no record of
	the requested type exists, it is customary to provide a SOA record, searching up the
	name hierarchy if necessary.
	I've tried to implement this in compose_answer(), although with some limitations.
	I only look in the cache, I don't search more then three levels up, and stop before
	the top level.

2004-03-28  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c,src/dns_answer.c
	There were some issues with add_cache_rr_add().

	First of all, the way it was used in rr_to_cache() (or rather not used) meant
	that if an "off topic" record was added for a name that lacked an entry in the
	cache, the rr set would be created with an incorrect serial number (namely zero).
	I've rewritten add_cache_rr_add so that it can create new cache entries if necessary.
	This simplifies the code in rr_to_cache() and ensures correct serial numbers.

	Secondly, in add_cache_rr_add() the ttl was compared with that of an existing rrset
	without adjusting for the min_ttl and max_ttl options. This could lead to all the
	previous records being deleted, retaining only the last one.

2004-03-27  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c
	In compose_answer(), if the rd (recursion desired) bit is set in the query
	and the response contains a CNAME record (while a different type of record was
	requested), always do a recursive query on the CNAME, even if we have already
	added a record of the requested type to the response.
	Failing to honor the rd bit will cause some resolver libraries to complain,
	even if the answer contains a record of the requested type.

	I've slightly changed the calling interfaces of add_to_response() and add_rrset()
	to make them more consistent and efficient.

	In add_rrset() I've fixed a memory leak on one of the error paths.

	In add_additional_rr(), the return value of add_rr() was not checked.
	If add_rr() fails, it will free *ans, and functions higher up the calling
	chain could be referencing freed memory.

	I've fixed a potential referencing of freed memory or double freeing in add_additional_a().
	If a call of add_additional_rr() fails, it will free *ans.
	Previously, add_additional_rr() could be called a second time, in which case
	the second call would be referencing freed memory or freeing it a second time..

2004-03-23  Paul Rombouts  <p.a.rombouts@home.nl>

	* configure.in, src/Makefile.in,src/pdnsd-ctl/Makefile.in,src/test/Makefile.in
	Fr�d�ric L. W. Meunier has reported that configure --srcdir option (for building
	in directory separate from the source directory) was broken.
	Should be fixed now.

2004-03-20  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/dns_query.c,src/helpers.c,src/icmp.c,src/main.c,src/netdev.c,src/ipvers.h,src/test/if_up.c,src/test/is_local_addr.c,src/test/tping.c,src/test/random.c,src/conf-parser.c
	I've eliminated the global variable run_ipv6 from the code.
	Enabling both the IPv4 and IPv6 protocols at the same time is not supported
	in pdnsd, so the value of run_ipv6 (if it is defined) is simply !run_ipv4.

	* src/dns.c,src/test/is_local_addr.c,src/test/tping.c
	It appears the option to compile pdnsd without IPv4 support (i.e. only IPv6
	support) was broken. Should be fixed now.

2004-03-19  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	I've discovered an incorrect use of cache locks in lookup_cache().
	We only read locks in place, it is possible for purge_cent() to delete a cache
	entry while another thread is trying to read it at the same time, which could
	lead to	trouble. I've rewritten purge_cent() so that it can be used to test
	whether something needs to be purged without actually deleting anything.
	If something needs to be deleted, purge_cent() will be called again with
	the proper read/write locks in place, excluding access to the cache for all
	other threads.

2004-03-18  Paul Rombouts  <p.a.rombouts@home.nl>

	* src/cache.c
	I've added a new function sort_rrl() for sorting the rr_l list using a merge-sort
	algorithm. Usually the insertion sort used by insert_rrl() is good enough, because
	new entries belong near the end most of the time. Reading entries from disk forms
	an exception, though, because the rrsets in the file are completely out of order
	w.r.t. timestamps, leading to quadratic time complexity of the insertion sort method.
	In that case it should be faster to simply append items at the end of the rr_l list
	and sort using a more efficient algorithm afterwords.
	pdnsd now seems to start up noticeably faster when reading large cache files.
	I've also considered using a more sophisticated data structure than a doubly linked
	list, but this will add considerable complexity to the code and use more memory.

2004-03-13  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Changed a declaration in udp_answer_thread() so that the buffer used for passing
	control messages on to sendmsg() is exactly the right size, instead of an arbitrary
	512 bytes.
	Also initialized the msg_flags of the struct msghdr passed on to sendmsg() to zero,
	to keep Valgrind from complaining about uninitialized bytes.

2004-03-12  Paul Rombouts <p.a.rombouts@home.nl>

	* src/icmp.c
	Fixed an incorrect call to select() in ping4(). A file descriptor set for detecting
	exceptions was initialized but not passed on to select(). This would lead subsequent
	code always to behave as if an IO exception had occurred.
	Valgrind seems to indicate that when a poll() call times out and returns 0,
	the revents field of the struct pollfd is not necessarily set.
	I've changed the code to check that the return value is > 0 before examining the
	revents field.

2004-02-06  Paul Rombouts <p.a.rombouts@home.nl>

	* src/conf-parser.c,src/conf-parser.h,src/conf-keywords.h
	I've rewritten the parser for the configuration file in C from scratch.
	(f)lex and yacc/bison are no longer needed to build pdnsd.

2004-01-16  Paul Rombouts <p.a.rombouts@home.nl>

	* src/main.c
	Load the cache from disk without locking cache access because pdnsd
	is still single-threaded at that point.

2004-01-15  Paul Rombouts <p.a.rombouts@home.nl>

	* src/cache.c,src/hash.c
	Moved the responsibility for freeing the cache entries referred by
	the hash buckets from destroy_cache() to free_dns_hash() (which is called
	by destroy_cache()). Previously, the cache and hash tables were already
	completely destroyed by the time free_dns_hash() was called, and there was
	nothing left for free_dns_hash() to free.

2004-01-14  Paul Rombouts <p.a.rombouts@home.nl>

	* src/hash.c,src/make_hashconvtable.c
	The hash conversion table is now generated at build time instead
	of at run time when pdnsd is started up.

2004-01-13  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns.c
	In add_host() fixed incorrect generation of IPV6 type of name for PTR record
	due to use of && instead of & as masking operator.

2004-01-13  Paul Rombouts <p.a.rombouts@home.nl>

	* src/icmp.c, src/dns_answer.c
	Use unsigned long instead of int error counters to reduce the danger
	of wraparound.

2004-01-06  Paul Rombouts <p.a.rombouts@home.nl>

	* src/main.c,src/thread.c,src/thread.h,src/server.c,src/status.c,src/dns_answer.c
	Initialize a global thread attribute object in main.c and use it to create all the detached
	threads, instead of initializing a separate attribute object for each new thread.

2004-01-06  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Check the return value of pthread_create() in udp_server_thread()
	and tcp_server_thread() to ensure that a new answer thread has actually
	been created and free resources if not.

2004-01-04  Paul Rombouts <p.a.rombouts@home.nl>

	* src/helpers.c,src/cache.c,src/conff.c,src/status.c
	Stop writing to control socket after an error has been detected.

2004-01-03  Paul Rombouts <p.a.rombouts@home.nl>

	* src/pdnsd-ctl/pdnsd-ctl.c
	Tried to make the error messages of pdnsd-ctl more helpful.
	The complete usage description is now only printed if the 'help' command
	is used. For problems with other commands a much shorter message is generated
	specific for that command.

2004-01-02  Paul Rombouts <p.a.rombouts@home.nl>

	* src/helpers.h
	Changed the definition of rhnlen(). For valid data this will make no difference,
	but it may change the behaviour of pdnsd in certain error situations.

2004-01-02  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns.c
	Optimized compress_name() some more.

2004-01-02  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Additional code cleanup in compose_answer().

2004-01-01  Paul Rombouts <p.a.rombouts@home.nl>

	* doc/pdnsd-ctl.8
	Updated the pdnsd-ctl man page.

2003-12-31  Paul Rombouts <p.a.rombouts@home.nl>

	* src/pdnsd-ctl/pdnsd-ctl.c
	Cleaned up some code.

2003-12-31  Paul Rombouts <p.a.rombouts@home.nl>

	* src/status.c,src/conff.h,src/conff.c
	Some further code cleanup in status.c.
	Labels for server sections are no longer limited to 32 chars,
	but can have arbitrary length. The string that is used to specify
	new DNS-addresses with the "pdnsd-ctl server" command can now also
	have arbitrary length.

2003-12-30  Paul Rombouts <p.a.rombouts@home.nl>

	* doc/html/doc.html
	Added information about CNAME and MX resource records, that were
	previously undocumented.

2003-12-26  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c
	Removed the function p_dns_resolve_from(). This function was essentially
	a call to p_recursive_query() with a dummy nocache argument.
	p_recursive_query() can now be called with nocache=NULL instead.

2003-12-26  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c
	Using a variable length array instead of an malloced buffer to hold the struct pollfd array
	in p_recursive_query(). This has the potential for causing portability problems, but I
	think that's unlikely because almost all the major C compilers I work with support variable
	length arrays nowadays.

2003-10-18  Paul Rombouts <p.a.rombouts@home.nl>

	* src/helpers.h,src/helpers.c
	Fixed a mistake that caused a compile error when using the --with-random-device
	configuration option.
	Thanks to Daniel Black for reporting this bug.

2003-10-02  Paul Rombouts <p.a.rombouts@home.nl>

	* conf-lex.l.in,src/conf-parse.y,src/conff.h,src/conff.c,src/dns_query.c
	Made the "delegation_only" feature configurable.

2003-09-25  Paul Rombouts <p.a.rombouts@home.nl>

	* src/helpers.c,src/helpers.h
	Added alternative implementations of strdup, strndup, stpcpy, getline and asprintf
	in an effort to make the code more portable.

2003-09-22  Paul Rombouts <p.a.rombouts@home.nl>

	* src/helpers.c,src/conf-parse.y
	Made some changes to the parser of the configuration file so that domain names
	missing a dot at the end will be tolerated.

2003-09-21  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c
	Implemented a first version of the "delegation-only" feature.
	It has been "hard-coded" to work for "com" and "net" zones,
	and is not yet configurable.

2003-09-21  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns.c
	Rewrote domain_match(). Also changed the way it is used.
	I believe it has a cleaner semantics now.

2003-09-21  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c
	Changed the order of the arguments of p_exec_query() and p_recursive_query()
	to make it more consistent with the other functions.

2003-09-18  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Reordered the code in process_query() so that a buffer for an error response is
	allocated only when it is actually needed.

2003-09-17  Paul Rombouts <p.a.rombouts@home.nl>

	* src/cache.c
	Added parentheses to correct mistaken operator precedence assumption in cache.c.
	!cent->flags&DF_NEGATIVE is parsed as (!(cent->flags))&DF_NEGATIVE but I think
	what Thomas Moestl must have intended was !((cent->flags)&DF_NEGATIVE).

2003-09-12  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c
	Fixed a mistake which caused the effect of the proxy_only option to be reversed.
	Thanks to Andrew M. Bishop <amb@gedanken.demon.co.uk> for reporting this bug.

2003-09-11  Paul Rombouts <p.a.rombouts@home.nl>

	* src/helpers.c
	Rewrote str2rhn() and rhn2str().

2003-09-10  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns.c
	Rewrote read_hosts(), the function that reads /etc/hosts-style input.
	I believe the parsing algorithm is more robust now.

2003-09-09  Paul Rombouts <p.a.rombouts@home.nl>

	* src/status.c,src/pdnsd-ctl/pdnsd-ctl.c
	Fixed a bug (my fault) that caused improper passing on of flags for the
	pdnsd-ctl source command.
	Also reordered some of the code, so that data is validated after all of it
	has been read from the control socket. This should prevent a "broken pipe"
	error message if data validation fails.
	Also fixed the reporting of success or failure of the pdnsd-ctl "neg" command.

2003-09-08  Paul Rombouts <p.a.rombouts@home.nl>

	* src/list.c
	Rewrote da_grow1() and da_resize() so that they automatically allocate an array
	if given a NULL argument. This makes the use of da_create() redundant in most cases.

2003-09-08  Paul Rombouts <p.a.rombouts@home.nl>

	* src/conf-parse.y,src/servers.c
	At the suggestion of Greg Norris, I changed the code to allow server sections in the
	configuration file that don't specify any IP addresses. Such a section will remain
	inactive until one or more IP addresses are assigned with the control utility pdnsd-ctl.

2003-09-04  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_answer.c,src/dns_query.c
	Oops: in my zeal to declare variables in the smallest possible scope, I ended up
	using a pointer to a struct that was out of scope. My understanding of compilers tells me
	it should work out OK in practice, but it is definitely a no-no.
	Used a union declared in a larger scope instead (which is ugly in another way,
	but equally efficient).
	Also removed a section of redundant code in udp_server_thread().

2003-09-01  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c
	Corrected the iteration range of a for loop in p_dns_cached_resolve(), which would
	otherwise cause an array to be indexed out of bounds in the function set_flags_ttl().

2003-08-31  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_answer.c
	Added cleanup handlers for freeing the resources passed on to udp_answer_thread() and
	tcp_answer_thread(). This should ensure the resources are freed even if the threads get
	canceled.

2003-08-30  Paul Rombouts <p.a.rombouts@home.nl>

	* src/cache.c
	Revised large portions of code in src/cache.c, used for adding and deleting entries in
	the cache. In particular, I rewrote purge_cache(), which I believe was incorrect.
	I wouldn't be surprised if this was the cause of the crashed (defunct) threads that some
	people were reporting.
	Also fixed some memory leaks.

2003-08-28  Paul Rombouts <p.a.rombouts@home.nl>

	* src/cache.c
	Eliminated the overhead of allocation debugging in the case that ALLOC_DEBUG is not defined.

2003-08-24  Paul Rombouts <p.a.rombouts@home.nl>

	* src/conf-parse.y
	No longer allow certain settings of the query_method option in the configuration file
	if pdnsd is not compiled with the necessary support.
	Thanks to Nikolaus Rath <Nikolaus@rath.org> for reporting the bug.

2003-08-23  Paul Rombouts <p.a.rombouts@home.nl>

	* src/netdev.c
	Fixed a bug in is_local_addr() where the result of fgetc(f) is restricted to type char
	before being compared to EOF, which can result in the comparison always being false.
	Thanks to Gerhard Tonn <GerhardTonn@gammatau.de> for reporting the bug.

2003-07-28  Paul Rombouts <p.a.rombouts@home.nl>

	* doc/html/index.html,doc/html/doc.html,doc/html/dl.html,doc/pdnsd-ctl.8,contrib/README
	Revised the documentation.

2003-07-21  Paul Rombouts <p.a.rombouts@home.nl>

	* src/main.c,src/status.c,src/icmp.c
	Setting stat_pipe=0 after opening or binding the control socket fails.
	This should prevent further use of the control socket if a problem with
	it has been detected previously.
	Also properly initialized the global variable int ping_isocket in src/icmp.c

2003-07-13  Paul Rombouts <p.a.rombouts@home.nl>

	* src/main.c
	Polished the code in main().

2003-07-04  Paul Rombouts <p.a.rombouts@home.nl>

	* src/helpers.c,src/dns_answer.c,src/dns_query.c
	Eliminated the use of inet_ntoa() in favor of the more modern inet_ntop().
	inet_ntop() makes more sense in threaded code and is also recommended in
	the glibc info pages.

2003-07-03  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c
	Fixed an allocation size error (not mine) in p_exec_query().
	The erroneous size is almost always larger than necessary, so in practice this bug
	just wastes memory. But there is also a possibility that the allocated buffer is too
	small, which would mean trouble.
	Also fixed two memory leaks on some of the error paths in p_exec_query().

2003-06-28  Paul Rombouts <p.a.rombouts@home.nl>

	* acconfig.h,configure.in,src/thread.h
	Extended the configuration option --with-thread-lib.
	Configuring with --with-thread-lib=linuxthreads2 will cause the alternative
	definition of THREAD_SIGINIT suggested by Thomas Moestl to be used.

2003-06-27  Paul Rombouts <p.a.rombouts@home.nl>

	* src/consts.h,src/consts.c,src/conff.c,src/conf-parse.y,src/dns_answer.c
	Added two new configuration options for policies of inclusion/exclusion lists.
	The new policies options are "simple_only" and "fqdn_only".
	This allows me to control to which name servers pdnsd will direct queries for
	simple host names.
	I also polished the code a bit in report_conf_stat(), used for reporting the current configuration.

2003-06-20  Paul Rombouts <p.a.rombouts@home.nl>

	* acconfig.h,configure.in,src/thread.h,src/thread.c
	Added a configuration option --with-thread-lib=nptl.
	This causes the macro THREAD_SIGINIT to be defined as empty in src/thread.h,
	and thread_sig() in src/thread.c is never used.

2003-06-11  Paul Rombouts <p.a.rombouts@home.nl>

	* src/thread.h
	Undid the change to the definition of THREAD_SIGINIT suggested to me by
	Thomas Moestl, after receiving a report of a problem with this change
	from someone running SuSE 7.0.

2003-06-06  Paul Rombouts <p.a.rombouts@home.nl>

	* src/dns_query.c:
	Discovered that I failed to preserve the semantics of Thomas Moestl's code
	when I rewrote a section of code in use_server(). Fixed.

2003-05-19  Paul Rombouts <p.a.rombouts@home.nl>

	* src/cache.c,src/conf-lex.l.in,src/conf-parse.y,src/conff.h,src/dns_answer.c,src/dns_query.c,src/servers.c:
	Merged fixes contained in patch file sent to me by Thomas Moestl with my own version.
	Changing the version to 1.1.8b1 as suggested by the patch file.

2003-02-26  Paul Rombouts <p.a.rombouts@home.nl>

	* pdnsd-1.1.7a-par.diff:
	Made one big patch file from all the changes I made up till now.
	Wrote a description of the changes in a file README.par
	Posted patch file on the web so others can use it.

2003-02-24  Paul Rombouts <p.a.rombouts@home.nl>

	* src/cache.c
	Changed the code that writes the cache to disk.
	Data is now written strictly sequentially, eliminating the need for fseek().
	This seems to have successfully solved the problem I had with corrupt cache files.

2002-05-27  Paul Rombouts <p.a.rombouts@home.nl>

	* ChangeLog:
	Started experimenting with the source code.
	Made many changes between 2002-05-27 and 2002-07-13.
	Too lazy to maintain the ChangeLog.

2002-01-06  Thomas Moestl  <tmoestl@gmx.net>

	* version: Call it 1.1.7.

2002-01-04  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, src/dns_query.c:
	Comment and debug message fixes, more assertions.

2002-01-03  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns.c, src/dns_answer.c, src/dns_query.c:
	More harmless fixes, correct some comments and debug messages, add more
	assertions.

	* NEWS, version: 1.1.7p2, correct NEWS entry.

	* src/helpers.c:
	Make sure the calling thread of pdnsd_exit() terminates immediately.

2002-01-02  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, src/helpers.c, src/icmp.c:
	Fix a few more harmless bugs, more paranoia.

	* src/status.c: Fix yet more, probably harmless, problems.

2002-01-01  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns.h, src/dns_answer.c, src/dns_query.c:
	Fix a few more possible buffer size problems, and add a bunch of
	assertions as last lines of defence.

2001-12-30  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns.c: Build fix (include error.h).

	* NEWS, version: Call it 1.1.7p1, and add a NEWS entry.

	* TODO: Reduce TODO to what actually is still needed.

	* src/dns.c, src/error.h, src/helpers.c:
	Add a bunch of robustness PDNSD_ASSERT()'s.

	* src/dns_query.c:
	Fix a bug which may possibly be remotely exploitable to gain access as
	the user pdnsd runs as.
	This was caused by a dumb single-character mistake :(

	* doc/Makefile.am, configure.in:
	Avoid confusing automake 1.5 by not putting a comment into a make rule.
	Fix CONFDIR passing.

	Submitted by:	GoTaR <gotar@poczta.onet.pl>

	* src/pdnsd-ctl/pdnsd-ctl.c:
	Avoid crashing when the buffer contents received using the status command
	are not terminated.

2001-10-14  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/SuSE/pdnsd.in, THANKS:
	Fix the stop case for the SuSE rc script: killproc requires the full
	path of the binary as argument (reported by Bernhard Pelz).

2001-09-23  Thomas Moestl  <tmoestl@gmx.net>

	* configure.in:
	Revamp the OS autodetect test. OpenBSD and (hopefully) NetBSD are no longer
	unsupported.

	* src/helpers.c, THANKS:
	Do not try to use arc4random when compiling for NetBSD (submitted by
	Thomas Stromberg).

2001-09-10  Thomas Moestl  <tmoestl@gmx.net>

	* COPYING.BSD: s/REGENTS/AUTHOR/ in one place.

	* src/cache.c:
	It is possible no record of the requested type is present after calling
	cr_add_cent_rr_int() (when the record was marked as being local), so
	check before dereferencing the pointer to the respective rrset.
	Leave the record unmodified when cr_check_add() returns 0.x

2001-07-26  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/RedHat/pdnsd.in:
	Add a workaround for @sysconfdir@ substitutions containing ${prefix}.
	Spotted by Robert Linden.

2001-07-04  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/RedHat/pdnsd.in:
	Add a condrestart handler to the Red Hat rc script, and do some general
	cleanup. Contributed by Christian Engstler.

2001-07-02  Thomas Moestl  <tmoestl@gmx.net>

	* src/error.h:
	Attempt to detect a gcc that cannot yet handle ANSI variadic macros,
	and work around this by using the old GCC-style variant.

	* src/conff.c:
	Remove a + at the start of a line that got in when merging a diff by
	hand.

	* src/servers.c: waitpid() returns a pid_t.

	* src/dns.c:
	It's sizeof, not sizof. This should unbreak the IPv6 build. Also silence
	some warnings with appropriate casts.

	* NEWS, version: Call it 1.1.6, and add a NEWS entry.

2001-07-01  Thomas Moestl  <tmoestl@gmx.net>

	* src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns_query.c, THANKS, version, AUTHORS:
	Added a modified version of Andreas Steinmetz's code for
	query_port_start and query_port_range, and added him to AUTHORS and
	THANKS.

2001-06-23  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c:
	Fix a bogon: deleted would not be reset correctly in the first
	purge_cache loop, which could cause pdnsd to loop forever when a
	negative record was after a deleted rr.

2001-06-21  Thomas Moestl  <tmoestl@gmx.net>

	* src/list.h:
	Add (currently unused) list macros that are going to be used in future
	code.

	* src/cache.c:
	Fix a bogon in the rw lock code: we need to wake up a writer if there
	are no readers. The old code was a leftover from a time when
	SUSP_THRESH was just r_pend * x.
	Fix a typo.

2001-06-13  Thomas Moestl  <tmoestl@gmx.net>

	* AUTHORS: Add mention of FreeBSD code to AUTHORS.

	* src/netdev.c:
	Add SIZEOF_ADDR_IFREQ (taken from FreeBSD: _SIZEOF_ADDR_IFREQ, net/if.h
	rev. 1.58.2.1) and add an appropriate copyright notice.
	The reason for this is that other BSDs don't have it, and we are not
	supposed to use underscored macros in portable software.

2001-06-12  Thomas Moestl  <tmoestl@gmx.net>

	* src/icmp.c: Fix double #inclusion of <netinet/ip.h>.
	Noticed by Sebastian Stark.

2001-06-08  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_query.c, THANKS:
	Allow underscores in the query names reported back, as the comment next
	to the decompress_name call already indicated (but the call gave NULL
	as the uscore parameter, which disables underscores normally).
	Add Michael Str�der, who spotted this, to THANKS.

2001-06-06  Thomas Moestl  <tmoestl@gmx.net>

	* src/servers.c, THANKS:
	Fix a bug discovered by Stefan Erhardt (and add him to THANKS): the
	return value of waitpid was misinterpreted.

2001-06-04  Thomas Moestl  <tmoestl@gmx.net>

	* Makefile.am, file-list.base.in, version:
	Bump version to 1.1.6p1; wire up COPYING.BSD so that it gets included
	in RPM's and tarballs.

	* COPYING.BSD:
	Add the BSD-Style copyright notice so that it can be included in binary
	distributions.

2001-06-03  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns.c, src/dns_answer.c, src/dns_query.c, src/helpers.c, src/status.c, NEWS, version:
	Bump version to 1.1.5, and add a NEWS entry for this release.

	Miscellaneous cleanups, mainly in the status.c code; fix a bug that
	could cause heap corruption (rhncpy always clobbered the whole buffer,
	but only the needed space was reserved in add_rr). This should solve
	the crashes some people were seeing (this bug is not an exploitable
	security hole as far as I know; the respective buffer is on the heap,
	as mentioned).

	* src/error.c:
	Paranoia: do not use the argument to crash_msg as a format string
	(crash_msg  is only used with constant strings, though).

2001-06-02  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns.c, src/dns.h, src/dns_answer.c, src/dns_query.c, src/error.h, src/hash.c, src/helpers.c:
	Correct underscore handling for SRV records, and a few comment fixes.

	* src/cache.c, src/conff.c, src/dns_query.c, src/error.h, src/helpers.h, src/status.c:
	Numerous non-critical argument fixes for printf-like functions.

	* src/dns.c: Remove superfluous \n's.

	* src/conf-parse.y, src/dns_answer.c, src/status.c:
	Correct some DEBUG_MSG nits, and fix two format string bugs. One of
	them could allow users that are allowed to use pdnsd-ctl with the
	server (when the status socket is enabled) to gain the privileges of
	the user that runs (the run_as user or the user that started pdnsd on
	Linux when strict_setuid is set to off) pdnsd. The status socket is
	disabled by default, and if it is enabled, it's default permissions
	are quite restrictive, so this isn't a problem for most.

2001-05-30  Thomas Moestl  <tmoestl@gmx.net>

	* src/status.c:
	Make the status permissions actually work (missed last time).

	* src/dns_answer.c, src/main.c, src/status.c, src/status.h:
	Move the status socket initialization to a place where it gets executed
	before any threads are started; this way, we can use umask to set the
	permissions, and avoid a (in this case harmless, but anyway) race
	condition.
	While being there, remove obsoleted comments and places referring to
	the now-socket as fifo.

2001-05-29  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c:
	Replace a misuse of CF_LOCAL with DF_LOCAL. This had no effect, because
	the values are the same.

2001-05-22  Thomas Moestl  <tmoestl@gmx.net>

	* src/hash.c, src/helpers.c, THANKS, acconfig.h, configure.in:
	Add an option for allowing underscores (_) in domain names. This
	violates the RFC's if enabled (which it isn't by default).
	Thanks to Eelco Vriezekolk for an initial patch.

	While being there, clean up configure.in and acconfig.c a bit.

	* src/helpers.c, src/status.c:
	Add a few comments about security implications.

	* src/cache.c, src/dns_answer.c, src/dns_query.c, src/helpers.c:
	Change some occurences of strcpy to strncpy. Again, no risk here, the
	buffer lentgh was carefully chosen, and while the data was partially of
	remote origin, it was carefully validated before entering the cache (and
	thus having a chance of being used by us).
	3 occurences remain: 2 in cache.c, where we allocate a sufficient amount
	of memory before (mimicking the non-portable strdup) and one where
	we copy a constant and which is obviously correct.

	* src/dns.c:
	Change two occurences of strcat to strncat. Again, no risk here, the
	buffer lentgh was carefully chosen, the data was validated and supplied
	by the starting user.

	* src/dns.c:
	Change a sprintf to a snprintf and enlarge a buffer a bit. This is pure
	paranoia (alrhough makes code review easier for others), because a.) the
	lengths were carefully chosen so that no overrun could occur and
	b.) this was locally supplied data.

2001-05-21  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/RedHat/Makefile.am:
	Add a missing semicolon in  the RedHat rc Makefile.am (discovered by
	Christian Engstler).

2001-05-19  Thomas Moestl  <tmoestl@gmx.net>

	* HACKING: Remove the mostly outdated HACKING file.

	* src/debug.c:
	Catch a corner case in the allocation debug helpers: realloc() with a
	size of 0 is effectively a free operation. To my knowledge, this is
	not done in the pdnsd sources, however.

	* src/test/test.sh:
	Use the correct error function, forgotten in last commit.

	* src/test/clnt-test.sh, src/test/srv-test.sh, src/test/test.sh:
	Misc small improvements in the regression test scripts, mostly
	adding configuration variables and common error handlers.
	Comment a little on the tests that are done in clnt-test.sh

	* src/rr_types.c: Fix a typo in a comment.

	* src/cache.c, src/debug.c, src/dns_answer.c, src/dns_query.c, src/error.h, src/hash.c, src/list.c, src/main.c, src/status.c, src/thread.c, src/thread.h:
	New ANSI variadic debug macros (finally), which print a timestamp and
	a thread ID now for easier debugging with many parallel queries.
	It should be considered to make those inline functions instead. However,
	we have the advantage that we use printf in place here and benefit
	from parameter checking without specifying obscure function attributes.

	* src/rc/SuSE/.cvsignore, src/test/.cvsignore, src/rc/.cvsignore, src/rc/Debian/.cvsignore, src/rc/RedHat/.cvsignore, contrib/.cvsignore, doc/.cvsignore, src/.cvsignore, src/pdnsd-ctl/.cvsignore, .cvsignore:
	Brush up the rotten (pre-autoconf!) .cvsignore files and add some where
	necessary.

2001-05-17  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/RedHat/Makefile.am, src/rc/RedHat/pdnsd.in, configure.in, pdnsd.spec.in:
	Red Hat rc script and RPM improvements by Christian Engstler.

2001-05-12  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl.c:
	Fix a place missed when converting rr_info.

	* version: It's 1.1.4, finally.

	* src/rr_types.c, version:
	Change some class values in the rr type structure to better values.
	Bump beta version.

2001-05-10  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/dns_answer.c, src/dns_query.c:
	Fix a signedness bug that could cause erraneous 0 ttls to be returned.
	Add some debug messages, and do some minor fixups.

2001-05-09  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/rr_types.c:
	Fix some bugs in the new conflict resolution code and make it more
	complete.

	* src/cache.c, version:
	Add conflict resolution code. This needs a bit more checking, and
	the tables might still need to be tweaked.
	Bump version.

	* src/pdnsd-ctl/pdnsd-ctl.c, src/Makefile.am, src/cache.c, src/cache.h, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/consts.c, src/consts.h, src/debug.c, src/dns.c, src/dns_answer.c, src/dns_answer.h, src/dns_query.c, src/dns_query.h, src/error.c, src/error.h, src/hash.c, src/hash.h, src/helpers.c, src/helpers.h, src/icmp.c, src/icmp.h, src/list.c, src/main.c, src/netdev.c, src/netdev.h, src/rr_types.c, src/rr_types.h, src/servers.c, src/servers.h, src/status.c, src/status.h, src/thread.c, src/thread.h, configure.in, version:
	Remove the old infrastructure that theoretically could have allowed for
	multiple cache subsystems. This ability was never used, and if it should,
	the caching should probably be split into two layers, a higher level
	common one and the actual caching backends.
	src/cacheing/cache.c and src/cacheing/native/*.[ch] were repo-copied to
	src/.
	Substitute "conf.h" with <conf.h> for includes.
	Purge records a little more often (when adding records, and when
	retrieving from the cache). Handle cache_size properly when using
	purge_cent.
	Introduce some infrastructure in rr_types.[ch] for a record conflict
	checker which is to be introduced shortly to enforce cache consistency
	even in the purge_cache=off case.

2001-05-04  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/RedHat/pdnsd.in, src/rc/SuSE/pdnsd.in, src/rc/Debian/pdnsd.in:
	Revert the last commit. It breaks the rc scripts by spamming them with
	make style variable expansions.

	* src/rc/SuSE/pdnsd.in, src/rc/RedHat/pdnsd.in, src/rc/Debian/pdnsd.in, AUTHORS, THANKS:
	Fix a rc script bug spotted by Frank Elsner, and add him to AUTHORS and
	THANKS.

2001-05-01  Thomas Moestl  <tmoestl@gmx.net>

	* version: Bump version to 1.1.4p2.

	* src/pdnsd-ctl/pdnsd-ctl.c, src/status.c:
	Fix some bogons and remove some unneeded code in the pdnsd-ctl
	interface.
	Fix spelling and line length bugs.

2001-04-30  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl.c, src/conf-parse.y, src/status.c:
	Some corrections for the authrec config file and the pdnsd-ctl noauth
	support.

	* src/pdnsd-ctl/pdnsd-ctl.c:
	Fix wrong argv index (using getopt changed the indices).

	* src/pdnsd-ctl/pdnsd-ctl.c, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns.c, src/dns.h, src/dns_query.c, src/status.c, THANKS, version, AUTHORS:
	Accumulated changes that should go in before 1.1.4:
	- merge Andrew M. Bishop's patch that adds a server label option
	- make local records authoritative for the domain by default, and add
	  the authrec option to change this
	- add the auth keyword to the pdnsd-ctl source option to support that
	- fix a bug in the conf-parse.y grammar causing a shift/reduce conflict
	- sync up AUTHORS and THANKS: add Andrew M. Bishop, Kevin A. Burton and
	  Michael Steinl
	- bump version to 1.1.4p1

	* src/conff.c, src/main.c:
	Fix two small bugs: the wrong element of argv was used for the pidfile
	option, which could cause pdnsd to segfault, and C_INCLUDED was always
	used in slist_add, regardless of the tp parameter.

	* src/helpers.c:
	Fix a bogon discovered by Michael Steiner:  the fread() return value
	was tested against bytes, not the number of items.

	* src/hash.c, src/hash.h, src/cache.c:
	purge_cache used to walk over the cache quite inefficiently when it was
	called from add_cache. Add a lazy mode for purge_cache which uses the
	rrset_l to be efficient in this special case.
	Add some #ifdef'ed-out-by-default code to debug the hash function.

2001-04-12  Thomas Moestl  <tmoestl@gmx.net>

	* NEWS: Add NEWS entry for 1.1.3.

	* src/dns.c, src/helpers.c, src/icmp.c, contrib/Makefile.am, contrib/README, version:
	IPv6, ICMP and build fixes. It's 1.1.3 now!

	* src/debug.c, src/debug.h: Add the new debug support files.

	* src/test/clnt-test.sh, src/cache.c, src/cache.h, src/error.h, src/list.c, src/list.h, src/main.c, src/status.c, src/status.h, src/Makefile.am, src/conf-parse.y, src/conff.h, src/dns.c, src/dns_answer.c, src/dns_query.c:
	Add allocation debug support. Some small cleanups before the upcoming
	1.1.3 release.

	* src/dns_query.h, src/helpers.c, src/list.c, src/conff.c, src/dns.c, src/dns_answer.c, src/dns_query.c:
	Lots of small bugfixes, cleanups, style and spelling fixes.

	* src/test/clnt-test.sh: Fix nc arguments.

	* src/test/clnt-test.sh, src/test/srv-test.sh, src/test/test.sh:
	Add regression test scripts.

2001-04-11  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl.c, src/cache.c, src/servers.c, src/dns_answer.c, src/helpers.c, src/helpers.h, src/icmp.c, src/main.c:
	Further cleanups and bug, style and spelling fixes.

	* configure.in: Use -g again in the CFLAGS for a while.

	* version: Beta version bump.

	* src/rc/SuSE/pdnsd.in:
	killproc does not seem to take the full path, but only the process name
	(which is what one would expect).

	* src/hash.c, src/netdev.c, src/rr_types.c, src/status.c, src/conf-parse.y, src/conff.c, src/helpers.c:
	Misc. smaller fixes, and fixes on the new features. Also clean up style
	and spelling in some places.

	* src/dns_answer.c:
	Bring the glibc pthread_cleanup_push/pthread_cleanup_pop return bug
	workaround into the main tree.
	Without this, a return between those two macros would cause pdnsd
	to crash on system using a glibc between 2.1.2 and 2.2.2 (and possibly
	others). This could e.g. be cause by a TCP connect() port scan.

2001-04-10  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl.c:
	Minor fixes, direct error messages to stderr.

	* src/list.c, src/list.h: Add the new list implementations.

	* src/cache.c, src/cache.h, src/conf-parse.y, src/dns.c, src/dns_answer.c, src/dns_query.c, src/helpers.c, src/helpers.h, src/conf-lex.l.in:
	Introduce rhnlen and rhncpy and make use of it instead of kluged-up
	strcpy/strlen in the appropriate places.
	Check that incoming names contain only legal characters in
	decompress_name, return RC_FORMAT otherwise (this would result in
	wrong handling only, but not in a security hole).
	Reorganzie compose_answer and make it more correct for multiple
	questions. Get rid of the algorithm that tries to add a higher
	level name server; this might be readded in another place somewhen.
	Use some more da_* instead of hand-built lists.
	Some style cleanups.

	* src/rc/RedHat/Makefile.am:
	Add K45pdnsd links for rc6.d (reboot) and rc0.d (halt) following a
	suggestion by Stas Sergeev.

2001-04-06  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl.c, src/cache.h, src/error.h, src/helpers.c, src/helpers.h, src/main.c, src/servers.c, src/status.c, src/conf-parse.y, src/conff.c, src/conff.h, src/dns.c, src/dns.h, src/dns_answer.c, src/dns_query.c, src/Makefile.am, version:
	Bump alpha version; introduce a generic dynamic array type and make use
	of it to ged rid of some ugly casts and redundant code.
	Minor fixes.

	* src/icmp.h, src/ipvers.h, src/conff.h, src/consts.h, src/dns.h, src/dns_answer.h, src/dns_query.h, src/helpers.h:
	Use macros without an underscore as first character to protect the
	headers. Underscores are reserved and should not be used in the
	application name space.

	* src/error.h: Add PDNSD_ASSERT, change style a little.

2001-04-03  Thomas Moestl  <tmoestl@gmx.net>

	* src/hash.c, src/netdev.c, src/servers.c, src/helpers.c, src/icmp.c, src/main.c:
	Another slew of small bugfixes, minor updates and small fixes.

	* src/rr_types.c, src/consts.c:
	Update rr_types.c copyright date, consts.c should have a rcsid string.

	* src/rr_types.c: cvs add rr_types.c.

	* src/dns.h, src/helpers.h, src/ipvers.h, src/rr_types.h, src/status.h, src/conf-parse.y, src/conff.h:
	cvs add rr_types.h that got missed before, update copyright dates,
	remove some old config cruft, some minor fixups.

	* src/conff.c, src/consts.c, src/dns_answer.c, src/error.c, src/conf-lex.l.in, src/conf-parse.y:
	Update copyright dates, fix some minor bugs. Update copyright dates.
	cvs add missed consts.c.

2001-03-28  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/hash.c, src/error.c, src/servers.c, src/dns_answer.c, version:
	Bump version to 1.1.3p4
	Fix some non-critical locking issues (none of them could be fatal).
	Adjust copyright dates.

	* src/hash.c: Make the hash compare case insensitive.

2001-03-25  Thomas Moestl  <tmoestl@gmx.net>

	* contrib/Makefile.am: Add Id tag to Makefile.am

	* src/cache.c, src/dns_answer.c, src/icmp.c:
	Some more type fixes overlooked in last commit.

	* src/conf-parse.y, src/conff.h, src/dns.h, src/dns_answer.c, src/dns_query.c, src/icmp.c:
	More type cleanups. Use time_t for time specifications throughout, and
	make lengths singed longs. Cast cleanup in icmp.c to fix alpha
	unalinged access faults.

	* contrib/dhcp2pdnsd, contrib/pdnsd_dhcp.pl, contrib/save_ram.pl, contrib/Makefile.am, contrib/README, configure.in, version, Makefile.am:
	It's 1.1.3p3 now.
	Change the contrib infrastructure: there is a Makfile.am in contrib/
	now. Rename Marko Stolle's pdnsd_update.pl to pdnsd_dhcp.pl and bring
	it up to date (adding the rc script and save_ram.pl).

	* src/helpers.c, src/dns.c, src/dns_query.c, AUTHORS, THANKS:
	Bring in Bjoern Fischer's changes to make pdnsd conserve the case of
	cached names, and add him to AUTHORS and THANKS.

	* configure.in: The gdbm backend is discontinued.

	* src/cache.c, src/hash.c:
	Cleanup and small bugfixes of the cache code (esp. locking).

	* AUTHORS, THANKS, file-list.base.in, pdnsd.spec.in:
	SuSE fixes by Christian Engstler.
	Add him to AUTHORS, THANKS.

2001-03-14  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_query.c:
	Fix a bug that could cause servers that were not used in the first
	parallel query not to be used at all (failure would be returned
	instead).

2001-03-13  Thomas Moestl  <tmoestl@gmx.net>

	* src/icmp.c: Add define for ip_p equivalent on Linux.

	* src/pdnsd-ctl/pdnsd-ctl.c, src/cache.c, src/dns_query.c, src/icmp.c, src/status.c, src/conf-parse.y, src/dns_answer.c, version:
	Bump alpha version, more alignment fixes. All casts should be correct
	now.

2001-03-12  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, src/dns_query.c, AUTHORS, THANKS:
	Add the alpha fixes by P.J. Bostley, and add him to THANKS and AUTHORS.

2001-03-10  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns.h, src/helpers.h:
	Remove prototype for removed function strtolower.
	Use unit16_t and uint32_t instead of unsinged short/long for dns
	protocol structures.

2001-02-25  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl.c, src/status.c, src/conf-lex.l.in, src/conf-parse.y, AUTHORS, Makefile.am, version:
	Add MX and CNAME for rr sections in the config file and MX setting
	for pdnsd-ctl.
	Typo fixes.

	* src/netdev.c: Two more fixes.

	* src/pdnsd-ctl/pdnsd-ctl.c, src/cache.c, src/dns.c, src/main.c:
	More small robustness fixes.

	* src/pdnsd-ctl/pdnsd-ctl.c, src/netdev.c, src/status.c, src/status.h, src/conf-parse.y, src/helpers.c, src/main.c, configure.in, version, Makefile.am, NEWS:
	A batch of robustness fixes. Move the status socket to the cache
	directory. Various cleanups.
	It's 1.3 now (hopefully to be released soon).

2001-02-21  Thomas Moestl  <tmoestl@gmx.net>

	* src/main.c, src/conf-lex.l.in:
	Fix breakage of the -mtu option and the query_method option (the parser
	would not recognize constants that contained underscores).

2001-02-20  Thomas Moestl  <tmoestl@gmx.net>

	* contrib/README, contrib/pdnsd_dhcp.pl, AUTHORS, Makefile.am, THANKS, file-list.base.in:
	Add Marko Stolle's pdnsd_update.pl DHCP update script, add him to THANKS,
	and bring a contrib/ directory in place.

2001-02-15  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, configure.in, version:
	Some minor build & misc fixes. Bump version to 1.1.2a and release a
	version with the spec file fixes to get proper Red Hat RPM's.

2001-02-09  Thomas Moestl  <tmoestl@gmx.net>

	* NEWS: Bring NEWS up to date.

	* src/icmp.c: Do not close the socket on error.

	* pdnsd.spec.in: Add spec file fixes for man pages by Sourav K. Mandal

2001-02-07  Thomas Moestl  <tmoestl@gmx.net>

	* version: It is now 1.1.2.

	* src/dns_query.c, src/main.c, Makefile.am, THANKS:
	Fix a too strict length checking that could cause SERVFAIL to be returned
	when the server returned NXDOMAIN. Add Markus Storm to THANKS (he has
	reported this bug and supplied helpful information).
	Minor tweaking in main.c.
	Remove emptying of GZIP_ENV in Makefile.am (this normally contains --best).

2001-01-27  Thomas Moestl  <tmoestl@gmx.net>

	* AUTHORS, THANKS:
	Add Michael Wiedmann to AUTHORS and THANKS for his pdnsd-ctl.8 man page.

	* doc/Makefile.am, doc/pdnsd-ctl.8, configure.in, Makefile.am:
	Add the pdnsd-ctl man page contributed by Michael Wiedmann. For this to
	build in a correct way, add doc/Makefile.am and move all doc and
	pdnsd.conf.sample related stuff in there.

2001-01-25  Thomas Moestl  <tmoestl@gmx.net>

	* src/main.c: Removed unneeded for the non-O_NOFOLLOW case.

2001-01-24  Thomas Moestl  <tmoestl@gmx.net>

	* src/main.c:
	Add a fchown and a fchmod to the new non-O_NOFOLLOW case (not yet used).

	* src/conf-parse.y, src/main.c, src/status.c: Misc small fixups.

	* version: It's called 1.1.1 now.

	* src/pdnsd-ctl/pdnsd-ctl.c, src/status.c, src/main.c:
	Fix command line parsing. Add code to securely create pid files under
	OSs that do not support the O_NOFOLLOW flag (those OSs are not supported
	yet, though).
	Fix a possible race condition in socket creation/chmod. We now create
	a directory in /tmp (or whatever TEMPDIR was set) to hold the socket.

	* src/dns.c, src/dns_answer.c, src/icmp.c, src/main.c, src/status.c:
	Another slew of copyright notice upgrades.

	* version, configure.in:
	Bump beta revision, fix typo (missing $) in configure.in

	* src/dns.c, src/dns_answer.c, src/status.c:
	Silence BSD compile time warnings.

	* configure.in:
	Cleanup, add autoconf code for building pdnsd on FreeBSD-CURRENT with the
	new additionally-linked libc_r.

2001-01-16  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, src/icmp.c, version:
	Bump beta revision, fix a comment. Also, generate ping id's using pdnsd's
	random wrappers instead of using rand() for paranoia.

2001-01-15  Thomas Moestl  <tmoestl@gmx.net>

	* src/helpers.c, configure.in: Improve wording.

	* src/helpers.c: Update copyright year (forgotten in last commit).

	* src/dns_answer.c, src/helpers.c, src/main.c, acconfig.h, configure.in, version:
	Bump versions. Small fixes (move socket intitializations from
	udp_server_thread to init_udp_sockets to prevent warning when startup
	takes long.
	Make arc4random an option for a query id RNG and make it the default
	on FreeBSD.

2000-12-07  Thomas Moestl  <tmoestl@gmx.net>

	* src/conf-parse.y, src/main.c, version:
	We are at 1.1.1p1. Removed the exec-uptest security warning printef if no
	explicit user is given in the strict_setuid case (it is not needed there,
	and confuses users).

2000-11-28  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/helpers.c:
	Converted cache locks to use condition vars and have lock contention
	prevention. Added comments where not converted.

2000-11-25  Thomas Moestl  <tmoestl@gmx.net>

	* AUTHORS, THANKS, pdnsd.spec.in:
	Added spec file patches by Bernd Leibing and added him to AUTHORS and
	THANKS.

2000-11-21  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/SuSE/Makefile.am: Fixed a hopefully last SuSE rpm build bug.

	* src/rc/SuSE/Makefile.am:
	Another one: allow rc.conf manipulation to fail for a clean
	rpm build (SuSE only).

	* file-list.base.in:
	Last-minute fix: correct filelist for rpm build to reflect the new name
	for the sample configuration.

	* version: It's 1.1.0 now.

2000-11-18  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl.c, src/cache.c, src/dns_query.c, version:
	Fixed a condition where the cache code did not give up a lock.
	Made the udp code use connect().
	Some small changes.

2000-11-16  Thomas Moestl  <tmoestl@gmx.net>

	* version: Calling it 1.1.0b3.

2000-11-15  Thomas Moestl  <tmoestl@gmx.net>

	* src/test/Makefile.am, src/pdnsd-ctl/Makefile.am, src/cache.c, src/Makefile.am, src/dns_answer.c, src/error.h, src/icmp.c, src/icmp.h, src/main.c, src/netdev.c, src/servers.c, src/thread.c, Makefile.am, configure.in, version:
	Enabled new rr support by default (some resolvers don't seem to like not
	supported answers - not our bug, but well).
	Made some globals volatile to avoid being bitten by optimisations.

2000-11-12  Thomas Moestl  <tmoestl@gmx.net>

	* TODO, version: Called it the first beta.

2000-11-11  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/conf-lex.l.in, src/conf-parse.y, doc/pdnsd.conf.in:
	renanmed rrneg to neg in the config file.
	Misc small fixes.
	pdnsd-ctl record xxx inval will now also invalidate local records.

	* src/conf-lex.l.in, src/conf-parse.y, src/dns_answer.c, src/status.c, pdnsd.spec.in:
	Added --sysconfdir=/etc as argument to configure in the spec file.
	Implemented the new rrneg config file section.

	* src/test/Makefile.am, src/pdnsd-ctl/Makefile.am, src/pdnsd-ctl/pdnsd-ctl.c, src/cache.c, src/cache.h, src/status.c, src/status.h, TODO:
	Added the neg option to pdnsd-ctl.

	* src/cache.c, src/Makefile.am, src/conf-lex.l.in, src/consts.h, src/dns.c, src/dns.h, src/dns_answer.c, src/dns_query.c, src/helpers.c, src/main.c, configure.in:
	Assorted fixes. The new features should be stabilized by now, will
	integrate the missing few features now.
	Also actived the tcp server by default.

2000-11-07  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, src/dns_query.c, src/icmp.c, src/ipvers.h, THANKS, TODO:
	Fixed a possible memory and socket leak reported by Erich Reitz.
	Implemented udp source address discovery for FreeBSD.

	* src/dns_query.c: Part 2 of yesterdays fix.

2000-11-06  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_query.c, version:
	Fixed a bug reported by Erich Reitz: pdnsd could leak fd's and memory if
	queries timed out.

	* src/cache.c, src/cache.h, src/Makefile.am, src/dns_answer.c, src/dns_query.c, TODO, configure.in:
	Sorted out some bugs for the new neg cacheing.

2000-11-05  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/dns_query.c, TODO:
	Negative cacheing support is now present, but largely untested.

	* src/conff.c, TODO:
	The output of pdnsd-ctl status is now complete with all currently
	supported options.

	* src/conf-parse.y, src/conff.c, src/conff.h, src/consts.h, src/conf-lex.l.in:
	Added the config file options for the nefative cacheing support.

2000-11-04  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/cache.h, src/conf-parse.y, src/dns.c, src/dns_query.c, src/status.c, version:
	The new cache infrastructure for negative cacheing is in place.
	Using and testing it remains.

	* src/cache.c, src/cache.h:
	First changes to support negative cacheing. This should not break
	anything, but the cache file format will be incompatible.

	* src/main.c, src/dns_answer.c:
	init_udp_socket() and init_tcp_socket() are now called after
	daemonizing on FreeBSD, as bind wants to lock the fd which
	can cause later calls to fail after an exit.

2000-11-03  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_query.c, src/icmp.c, src/servers.c:
	Minor bugfixes and repository cleanup.

2000-11-02  Thomas Moestl  <tmoestl@gmx.net>

	* src/icmp.c, TODO, version:
	Called it 1.0.16p4. Fixed some compatability problems with the new code;
	the ipv4 implementation seems to be fairly stable, the ipv6 one needs
	some testing with dest unreach messages.

	* src/icmp.c, src/main.c:
	Rewrote large parts of the ping implementation to be more portable.

2000-11-01  Thomas Moestl  <tmoestl@gmx.net>

	* acconfig.h, configure.in, version:
	Some config fixes, version to 1.0.16p3. SOCKET_LOCKING should be
	off by default, as sendmsg can block.

	* src/pdnsd-ctl/pdnsd-ctl.c, src/error.h, configure.in:
	Removed -W* arguments from CFLAGS that were implied by -Wall.

	* src/thread.c, configure.in:
	Added some more safety tests to configure.in, and made it give
	an error on some conditions. Also made configure do poll and usleep
	detectione.

	* src/cache.h, src/test/Makefile.am, src/dns_answer.c, src/error.c, src/error.h, src/helpers.c, src/main.c, src/servers.c, src/status.c, src/thread.c, src/thread.h, src/Makefile.am:
	Code cleanup. Beautified some macros, and moved the thread
	specific things from error.[ch] over to the new thread.[ch].
	Also introduced usleep_r which tries to be thread safe for
	different Unices.

2000-10-31  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl, src/pdnsd-ctl/pdnsd-ctl.c:
	The pdnsd-ctl binary got into cvs. Fixed that.

	* src/pdnsd-ctl/pdnsd-ctl, src/cache.c, src/cache.h, src/error.c, src/helpers.c, src/main.c, version:
	Another set of FreeBSD compatability patches. This seems to catch
	most of the problems, and pdnsd should be useable with libc_r now.

2000-10-30  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/pdnsd-ctl, src/conff.c, src/dns_answer.c, src/dns_query.c, src/helpers.c, src/icmp.c, src/main.c, AUTHORS, Makefile.am, THANKS, configure.in, version:
	FreeBSD fixes, mostly contributed by Roman Shterenzon.

2000-10-25  Thomas Moestl  <tmoestl@gmx.net>

	* src/pdnsd-ctl/Makefile.am, src/pdnsd-ctl/pdnsd-ctl:
	pdnsd-ctl was not in cvs.

	* src/dns_query.c, src/error.h, configure.in: Some fixups for 1.0.15.

2000-10-23  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, src/dns_query.c, configure.in:
	Several fixes for pdnsd to work better when it receives error replys.

	* src/dns.c, src/dns_answer.c:
	Fixed another memory leak on an error path in dns_answer.c and did
	a pointer signedness fixup in dns.c

2000-10-21  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, AUTHORS:
	Applied a patch by Paul Wagland that fixes some spelling mistakes
	and some memory leaks on error paths.

	* src/dns_query.c, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns_answer.c, NEWS, version:
	Bug fixes. Added the randomize_recs option and turned it on
	by default.

2000-10-20  Thomas Moestl  <tmoestl@gmx.net>

	* src/helpers.c, src/dns.c, src/dns_query.c:
	Fixes for the paranoid option to work with root servers
	properly.

	* src/dns_query.c, src/dns.h, src/dns_answer.c, AUTHORS, THANKS:
	Applied a patch by Paul Wagland for bind9-compatability and added
	him to AUTHORS and THANKS.

2000-10-19  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, NEWS, version:
	Another POLL_* fix. It is now called 1.0.14.

	* src/dns_answer.c, src/dns_query.c, src/icmp.c: BSD build fixes.

	* src/dns_query.c:
	Made p_recurdive_query return immediately if a query returns
	NXDOMAIN.

	* src/dns_query.c, Makefile.am:
	Some bugifixes. It is now called 1.0.13. Releasing.

	* src/cache.c, src/dns_query.c, AUTHORS, NEWS:
	Updated AUTHORS and NEWS. Made destroy_cache() lock the cache so
	that no thread can access the cache afterwards (could lead to
	crashes).

	* src/helpers.c, NEWS, THANKS:
	Integrated a security fix contributed by Olaf Kirch: when
	changing user IDs, pdnsd did not reinitialize the supplementary
	group list, meaning that the process still had the privileges
	of the supplementary groups the original user was member of.

	* src/conf-lex.l.in, src/conf-parse.y, Makefile.am, TODO, version:
	Introduced the par_queries option.

	* src/dns_answer.c, src/dns_query.c, TODO:
	Updated TODO, did some fixups for string handling.

	* HACKING: Added HACKING with some comments about coding style.

2000-10-18  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, src/dns_query.c, src/error.h, src/main.c, TODO:
	Revieved and fixed the new dns_query.c-poll/select loops.

	* src/test/tping.c, src/dns_query.c, src/icmp.c:
	Fixed the new poll/select ping support.

2000-10-17  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_query.c, src/icmp.c, TODO:
	Got rid of the O_NONBLOCK loop in the icmp.c ping implementation.
	Beta tesing pending.

	* src/rc/Debian/Makefile.am, src/conff.c, src/conff.h, src/dns_query.c, src/dns_query.h, THANKS, TODO, acconfig.h, configure.in:
	Corrected the Debian rc script (bug reported by Michael M�ller).
	Got rid of the nonblocking socket things in dns_query.c, and
	using poll/select now.
	Testing (esp. --no-poll) remains.

	* src/dns_answer.c:
	Got rid of O_NONBLOCK read loops in dns_answer.c, using poll/select
	now instead (after one issue about boundaries was cleared up).

2000-10-16  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/SuSE/Makefile.am, src/rc/RedHat/Makefile.am, src/rc/Debian/Makefile.am:
	The generated rc scripts do not need to be in the distribution.

	* src/conff.c, src/main.c:
	Fixed a server structure members in conff.c. Only delete the socket
	if we are in status pipe mode now.

	* src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns_answer.c, src/dns_query.c, acconfig.h, configure.in:
	Added the --enable-tcp-subseq and --with-tcp-qtimeout configure
	options, added the tcp_qtimeout conf file option, tested things.
	1.0.12 is ready for release.

2000-10-15  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c, TODO, acconfig.h:
	Added TCP timeouts to the answer code. Still need an option in the
	conf file and documentation for that (besides beta testing).

	* src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/consts.h, src/dns_query.c, src/helpers.c, src/helpers.h, NEWS, TODO:
	Introduced domain inclusion/exclusion lists in the server section
	(new options include=, exclude=, policy=).

2000-10-14  Thomas Moestl  <tmoestl@gmx.net>

	* src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns_answer.c, src/main.c, NEWS, TODO, version:
	Upped version, updated NEWS and TODO and implemented a process
	count limit.

2000-10-13  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/Debian/pdnsd.in, src/main.c:
	Added the --pdnsd-user option, and made the Debian rc script
	use it rather than trying to parse the config file itself.

2000-10-11  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/SuSE/pdnsd, src/rc/SuSE/pdnsd.in, src/rc/RedHat/pdnsd, src/rc/RedHat/pdnsd.in, src/rc/Debian/pdnsd, src/rc/Debian/pdnsd.in, AUTHORS, THANKS, configure.in:
	Added the 'configure'-able rc scripts contributed by Carsten Block
	and added him to THANKS and AUTHORS.

	* src/main.c:
	Added O_NOFOLLOW to the pidfile open() call (if it is defined)
	to prevent users creating files as the pdnsd user (using links)
	if the admin put the pidfile in a world-writeable directory
	against all good advice.
	This is not a bug fix! Admins were not, and are still not supposed
	to put the pidfile in a directory that is writeable for untrusted
	users!

2000-10-10  Thomas Moestl  <tmoestl@gmx.net>

	* THANKS: Added Milan P. Stanic to THANKS.

	* src/main.c:
	Fixed a missing O_WRONLY in the open() call for pidfile operation.

2000-10-08  Thomas Moestl  <tmoestl@gmx.net>

	* src/Makefile.am, src/dns.c, src/dns_answer.c, configure.in, version, acconfig.h:
	Released 1.0.11.
	Two security fixes in dns.c and dns_answer.c, and misc. smaller issues.

	* src/Makefile.am, src/conf-parse.y, src/dns_answer.c, src/dns_query.c, src/icmp.c, src/servers.c, AUTHORS, THANKS, TODO, acconfig.h, configure.in, version:
	1.0.10 was released some time ago ;-)
	This had some IPv6 fixes.
	Also fixed minor bug when using SOCKET_LOCKING.

2000-08-28  Thomas Moestl  <tmoestl@gmx.net>

	* src/dns_answer.c: Fixed a parameter mismatch in getsockopt()

	* Makefile.am:
	Applied Sourav K. Mandal's rpm build patch to the toplevel
	Makefile.am

2000-08-27  Thomas Moestl  <tmoestl@gmx.net>

	* src/conf-lex.l.in, src/conf-parse.y, src/consts.h, src/servers.c, version:
	Added diald support. It's now called 1.0.9.

	* src/conf-parse.y, src/conff.c, src/netdev.c, pdnsd.spec.in:
	Fixed some ugly typos in conf-parse.y and netdev.c.
	Since I have no further bug reports and these bugs make some
	things inconvenient, I will release 1.0.9 immediately.

2000-08-26  Thomas Moestl  <tmoestl@gmx.net>

	* pdnsd.spec.in: small spec fix.

	* NEWS, configure.in: Last fixups for 1.0.8. Released it.

	* Makefile.am: Set mode and owner for cache file.

	* src/conf-parse.y, src/dns_answer.c, src/netdev.c, acconfig.h, configure.in, version:
	Misc fixes. Hopefully fixed the UDP socket problems under Linux SMP.

2000-08-20  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/dns_answer.c, AUTHORS, THANKS, configure.in, pdnsd.spec.in, version:
	Build fixes by Alexandre Nunes, spec fixes (does now set distro for
	configure), first attempt at an "error in udp send"-fix, and fix
	for a problem with having records for the root domain in the disk
	cache file.

2000-08-13  Thomas Moestl  <tmoestl@gmx.net>

	* src/netdev.h, src/servers.c, src/status.c, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/consts.h, src/dns.c, src/dns.h, src/main.c, src/netdev.c, AUTHORS, THANKS:
	Some minor fixes. Integrated the ppp device patch by Ron Yorston.

2000-08-12  Thomas Moestl  <tmoestl@gmx.net>

	* configure.in:
	configure.in was missing in repository. Also removed debugging
	flag for build.

	* src/main.c: Made the pid file handling safe for directories.

	* src/dns.c: Part II of the last fix.

	* src/dns.c:
	Fixed a nasty bug in decompress_name which would produce errors very
	rarely. That was a off-by-one bug, but on the safe side (no overflow,
	stopping one by too early).

	* src/main.c:
	Fixed several possible problems with strncat(). None of these was
	critical or involved remote data.

2000-08-08  Thomas Moestl  <tmoestl@gmx.net>

	* src/main.c: Changed FreeBSD signal latency to 250 ms.

	* src/main.c, acconfig.h:
	A set of last-minute FreeBSD fixes. pdnsd does now NEED linuxthreads on
	BSD.

2000-08-07  Thomas Moestl  <tmoestl@gmx.net>

	* version: It's now called 1.0.7.

	* src/main.c, doc/pdnsd.conf.in, Makefile.am: Misc build&BSD fixes.

	* src/conff.c, src/conf-parse.y, version:
	Version set to the hopefully last beta. Fixed the proxy_only option.

2000-08-05  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/SuSE/Makefile.am, src/rc/RedHat/Makefile.am, src/rc/Debian/Makefile.am, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns_query.c, src/status.c, doc/pdnsd.conf.in, Makefile.am, TODO:
	Added the proxy_only options. Some build fixups.

2000-07-30  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/SuSE/Makefile.am, src/rc/RedHat/Makefile.am, src/rc/Debian/Makefile.am, src/rc/Makefile.am, src/main.c, src/status.h, AUTHORS, INSTALL, Makefile.am, TODO, version:
	Many small fixups for 1.0.7.

2000-07-29  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/SuSE/Makefile.am, src/rc/RedHat/Makefile.am, src/rc/Debian/Makefile.am, src/rc/README, src/status.c, src/servers.c, Makefile.am, TODO, acconfig.h:
	Assorted fixes.

	* src/cache.c, src/hash.c, src/dns.h, src/dns_answer.c, src/dns_query.c, src/icmp.c, src/ipvers.h, src/servers.c, src/servers.h, src/status.c, src/status.h, src/Makefile.am, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns.c, AUTHORS, Makefile.am, THANKS:
	Big heap of updates and fixes. Incorporated build changes from Sourav
	K. Mandal and pcmcia SCHEME support by Stephan Boettcher.

2000-07-22  Thomas Moestl  <tmoestl@gmx.net>

	* src/rc/Debian/pdnsd:
	Applied a patch by Markus Mohr to his debian rc script, which I had
	broken in some way.

2000-07-21  Thomas Moestl  <tmoestl@gmx.net>

	* src/cache.c, src/main.c, src/status.c, src/status.h:
	Worked on the new status socket (pdnsd-ctl) option.

	* src/Makefile.am, version: Upped version, fixed Makefile.am

	* src/cache.c, src/hash.c, src/hash.h, src/cache.h, src/Makefile.am, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/dns.c, src/dns.h, src/dns_answer.c, src/dns_query.c, src/dns_query.h, src/helpers.c, src/helpers.h, src/ipvers.h, src/main.c, src/status.c, src/status.h, AUTHORS, Makefile.am, THANKS, acconfig.h:
	Updated AUTHORS and THANKS. Merged in patches by Sourav K. Mandal
	and Lyonel Vincent.

2000-07-20  Thomas Moestl  <tmoestl@gmx.net>

	* doc/pdnsd.conf: Added pdnsd.conf. Well...

	* src/dns_query.c, src/dns_query.h, doc/pdnsd.conf:
	Added some ommited files.

	* src/test/Makefile.am, src/test/if_up.c, src/test/is_local_addr.c, src/test/random.c, src/test/tping.c, src/rc/SuSE/Makefile.am, src/rc/SuSE/pdnsd, src/rc/RedHat/Makefile.am, src/rc/RedHat/pdnsd, src/rc/Debian/pdnsd, src/rc/Makefile.am, src/rc/README, src/Makefile.am, src/conf-lex.l.in, src/conf-parse.y, src/conff.c, src/conff.h, src/consts.h, src/dns.c, src/dns.h, src/dns_answer.c, src/dns_answer.h, src/error.c, src/error.h, src/helpers.c, src/helpers.h, src/icmp.c, src/icmp.h, src/ipvers.h, src/main.c, src/netdev.c, src/netdev.h, src/servers.c, src/servers.h, src/status.c, src/status.h, doc/pdnsd.conf.in, Makefile.am, acconfig.h, file-list.base.in, pdnsd.spec.in:
	Checked in the pdnsd files at their new locations.

	* doc/pdnsd.conf, Makefile, a-conf.sh, cache.c, cache.h, conf.l.templ, conf.y, conff.c, conff.h, config.h.templ, consts.h, dns.c, dns.h, dns_answer.c, dns_answer.h, dns_query.c, dns_query.h, error.c, error.h, exec-flex.sh, hash.c, hash.h, helpers.c, helpers.h, icmp.c, icmp.h, ipvers.h, main.c, netdev.c, netdev.h, pdnsd-redhat.spec.templ, pdnsd-suse.spec.templ, servers.c, servers.h, status.c, status.h, version:
	Removed the moved files. Will add the new ones soon.

2000-07-16  Thomas Moestl  <tmoestl@gmx.net>

	* TODO: New tasks in TODO.

2000-07-15  Thomas Moestl  <tmoestl@gmx.net>

	* TODO:
	Updated TODO: Autoconf support was contributed by Sourav K. Mandal

	* conff.h, dns_query.c, ipvers.h, cache.c:
	Fixed some minor bugs and a showstopper in cache.c that caused
	crashes in some situations.

2000-07-12  Thomas Moestl  <tmoestl@gmx.net>

	* dns_query.c, error.c, error.h, main.c:
	Made pdnsd ignore SIGPIPE, which seemed to be responsible for some
	crashes.
	Accept (grudgingly) SOA rr's where NS ones would be The Right Thing.

2000-07-10  Thomas Moestl  <tmoestl@gmx.net>

	* AUTHORS, THANKS, conff.c:
	Updated AUTHORS, THANKS, and the fprintfs for the status pipe in
	conff.c

	* TODO, config.h.templ, dns.h, dns_answer.c, dns_query.c, dns_query.h, main.c, version:
	Added UDP queries and gave the user the choice between TCP and UDP
	queries (UDP is the default now). Made the TCP server optional.
	Fixed a authoritative record handling bug. Added pidfile support.

2000-07-07  Thomas Moestl  <tmoestl@gmx.net>

	* doc/pdnsd.conf:
	Inserted run_as="nobody"; again, it is The Right Thing and people
	should use it.

	* Makefile:
	The pdnsd cache directory is now created as nobody, since the
	default run_as in the example pdnsd.conf is also nobody.

	* doc/pdnsd.conf:
	Commented the run_as option out (people may run into permission
	problems).

	* version: Upped version to 1.0.5

	* AUTHORS, THANKS, conf.l.templ, conf.y, conff.c, conff.h, dns_answer.c, icmp.c, icmp.h, main.c, version:
	Folded in the server_ip option code as contributed by Wolfgang Ocker
	and extended it to IPv6. Fixed a bug in IPv4 ping in IPv6 mode.

2000-07-06  Thomas Moestl  <tmoestl@gmx.net>

	* cache.c, dns_query.c:
	Killed a bug which could cause crashes with more than 2 servers.

	* cache.c: Fixed a bug reported by Bert Frederiks that would break the
	serve_aliases option when only one character was between official
	name and alias in the /etc/hosts-style file.

2000-07-04  Thomas Moestl  <tmoestl@gmx.net>

	* pdnsd-suse.spec.templ: The SuSE spec now uses the new makefile rule.

	* Makefile, THANKS, dns_query.c, helpers.c, version:
	Added people to THANKS, fixed a bug that caused uppercase hosts/
	rr-section entries to be ignored in the cache, fixed the SuSE
	makefile for pdnsd to run_as nobody, and other small fixups.

2000-07-03  Thomas Moestl  <tmoestl@gmx.net>

	* dns_answer.c:
	First change after release of 1.0.4: The questions received
	are now properly written into the debug file when starting
	with -g -d.

	* config.h.templ, dns_query.c:
	Fixed a possible way to get around paranoid restrictions.

	* version: Set version to 1.0.4

	* doc/pdnsd.conf: Added an entry for the paranoid option.

	* cache.c, config.h.templ, dns_answer.c, dns_query.c, ipvers.h:
	Revisions and fixups. The complete code revision is now complete.

2000-06-29  Thomas Moestl  <tmoestl@gmx.net>

	* dns_query.c: Overhaul.

	* dns_answer.c, dns_query.c, config.h.templ:
	Code overhault continued. dns_answer.c is finished.

2000-06-27  Thomas Moestl  <tmoestl@gmx.net>

	* conff.c, dns_answer.c, icmp.c, netdev.c, servers.c, status.c:
	Continued code overhaul. Fixed several bugs, and simplified some
	code.

	* conf.l.templ, conf.y, conff.c, ipvers.h, version: Fixups.

2000-06-26  Thomas Moestl  <tmoestl@gmx.net>

	* hash.c: Revised; fixed a minor bug.

	* cache.c: Overhauled.

	* dns_query.c, error.c, helpers.c, helpers.h, ipvers.h, main.c, version, dns.c:
	Manual code overhaul. Numerous small patches, greatly simplified
	decompress_name().

2000-06-25  Thomas Moestl  <tmoestl@gmx.net>

	* config.h.templ:
	Made the C random() RNG the default (using /dev/urandom, we suck up
	too much randomness on high load).

	* error.c, error.h, icmp.c, icmp.h, main.c:
	Small cleanups. Makes the testsuite compilation easier.

	* Makefile, config.h.templ: Preparing for release of 1.0.4.

2000-06-24  Thomas Moestl  <tmoestl@gmx.net>

	* Makefile, THANKS, a-conf.sh, dns_answer.c, dns_query.c, error.c, version:
	Fixed bugs with the paranoid option, connect() timeout handling, and
	a incompatability in response handling that caused the glibc
	resolver to misunderstand error messages pdnsd generated on unknown
	query types. This bug, that was reported by James MacLean, could
	for example cause ssh to hang some time.

	* Makefile, NEWS, conf.l.templ, conf.y, conff.c, conff.h, config.h.templ, dns.c, dns_query.c, dns_query.h, helpers.c, helpers.h, icmp.c, icmp.h, main.c:
	Added the paranoid option, and modified the ping uptest so that it
	works with strict_setuid. Also made strict_setuid=on the default.
	1.0.4 should be out soon.

2000-06-23  Thomas Moestl  <tmoestl@gmx.net>

	* doc/pdnsd.conf: Added a run_as= line, which is sensible normally.

	* Makefile, conf.l.templ, conf.y, conff.c, conff.h, dns_answer.c, dns_answer.h, helpers.c, helpers.h, main.c, servers.c, status.c, version:
	Some fixups, added the run_as and strict_setuid security options.

	* THANKS: Updated.

	* AUTHORS, ipvers.h, main.c, netdev.c, version:
	Fixed some definitions for glibc2.0-users. Repaced the return at the
	end of main() with _exit(). Should not build and run OK on glibc 2.0
	boxen.
	Fixed a typo in netdev.c

	* ipvers.h:
	Fixed a typo in ipvers.h to fix compile problems on systems without
	an IPv6-supporting C library, and possible IPv6 problems using the
	status pipe.

	* error.c, version:
	Fixed a bug that could cause signals to be delivered to the wrong
	process.

2000-06-22  Thomas Moestl  <tmoestl@gmx.net>

	* version: Set version to 1.0.1.

	* cache.c, dns_answer.c, error.c, error.h, main.c, pdnsd-suse.spec.templ:
	Fixed misc issues reported by Jonathan Hudson and Joachim Dorner, one
	of them a real showstopper in cache.c.

	* Makefile, NEWS, README, cache.h, config.h.templ, version:
	Updated things for 1.0.0 and released it finally.

	* AUTHORS, THANKS: Updated THANKS and AUTHORS

	* NEWS, a-conf.sh, cache.c, conf.l.templ, conf.y, conff.c, conff.h, dns_answer.c, dns_query.c, error.c, error.h, main.c, servers.c, status.c:
	Fixed a-conf.sh and cleaned up signal handling as far as it can be
	done ;-). Added the max_ttl option.

2000-06-21  Thomas Moestl  <tmoestl@gmx.net>

	* dns_answer.c, error.c, error.h, main.c, servers.c, status.c:
	More signal fixes. This is a real pain with LinuxThreads.

	* NEWS, cache.c, dns_answer.c, error.c, error.h, helpers.c, helpers.h, main.c, servers.c, status.c, version:
	Fixups for signal handling. This is more than only a little tricky
	using the linuxthreads library. This hopefully fixes the deadlocks
	we had on signals.

2000-06-13  Thomas Moestl  <tmoestl@gmx.net>

	* AUTHORS, THANKS: Updated credits.

	* a-conf.sh:
	A primitive configure-like script intended as drop-in replacement
	until autoconf support finally comes.

	* .cvsignore, Makefile, cache.c, dns_query.c, ipvers.h, servers.c, version:
	Added a primitive configuration script as drop-in. Killed some bugs
	and changed the recently added linkdown_kluge option following
	suggestions from Daniel Smolik.

2000-06-12  Thomas Moestl  <tmoestl@gmx.net>

	* dns_query.h, exec-flex.sh, Makefile, cache.c, conf.l.templ, conf.y, conff.c, conff.h, config.h.templ, dns_query.c:
	Numerous cleanups and fixes. Implemented the linkdown_kluge option
	as proposed by Daniel Smolik. Hope to get ready for 1.0.0 know.

2000-06-10  Thomas Moestl  <tmoestl@gmx.net>

	* Makefile, NEWS, TODO, dns_answer.c:
	Modified some stuff in dns_answer.c (if no nameserver for a knot in
	the dns namespace is found now, its predecessors are tried now in
	order to return accurate authority results). This will be paid with a
	little more beta time, so the Makefile has developer switches again.
	Corrected NEWS and TODO.

	* Makefile, config.h.templ, dns_answer.c, dns_query.c, dns_query.h, hash.h, helpers.c, version:
	Removed some dead code, fixed some really minor bugs. Version is up
	to 1.0.0p7, which is hopefully the last beta.

	* Makefile, config.h.templ:
	Fixed things up for the 1.0.0 distribution version

2000-06-06  Thomas Moestl  <tmoestl@gmx.net>

	* Makefile, config.h.templ, icmp.c, netdev.c:
	Some minor comment fixes.

	* Makefile, TODO, main.c, version:
	BSD fix in Makefile and help update. It is now called 1.0.0p6. TODO
	was updated to reflect the project status.

	* dns_answer.c:
	BSD & misc fixes. pdnsd runs now nicely on my FreeBSD 4.0 box.

	* dns_answer.c, ipvers.h:
	Fixed IPv6 UDP dest address recovery. Also fixed a real stupid bug in
	ipvers.h.

	* cache.h, dns_query.c, error.h:
	Added DEBUG_MSG6 macros. Cleaned up requery handling.

	* dns.c, dns_answer.c, dns_query.c, dns_query.h:
	Fixed another heap of bugs, introduced some sanity checks, no requery
	on answers that have ra not set now.

2000-06-05  Thomas Moestl  <tmoestl@gmx.net>

	* cache.c:
	Fixed write_disk_cache.

	* cache.c, cache.h:
	Fixes for rr handling.

2000-06-04  Thomas Moestl  <tmoestl@gmx.net>

	* cache.c, dns_answer.c, dns_query.c:
	Fixes again: some missing checks for rrset existence added.

	* cache.c, dns_answer.c, helpers.c, icmp.c:
	Fixes for the new/modified code and its side effects on old code ;-)

	* ChangeLog.old, NEWS, cache.c, conf.l.templ, conf.y, conff.c, config.h.templ, dns.c, dns_answer.c, dns_query.c, error.c, hash.c, helpers.c, icmp.c, main.c, netdev.c, servers.c, status.c:
	Folded the ChangeLog and NEWS of the 0.9.x tree back in and added NEWS for the
	upcoming 1.0.0 release. Some compile fixes. Reorganized config.h.templ. Made
	the inclusion of the rcsid strings into the executable optional.

	* cache.c, dns_answer.c:
	Pile of fixes on recently added/modified code.

2000-06-03  Thomas Moestl  <tmoestl@gmx.net>

	* .cvsignore, Makefile, lex.inc.h:
	lex.inc.h should not be in CVS (it is automatically generated by
	exec-flex.sh). It should also be deleted by 'make mclean'.

	* TODO, cache.c, dns_answer.c, dns_query.c, lex.inc.h:
	rfc2181 conformance should be reached by now. Updated TODO. Bugfixing
	remains.

	* doc/html/.cvsignore, doc/html/dl.html, doc/html/doc.html, doc/html/faq.html, doc/html/index.html:
	Removed the html documentation from CVS. It is maintained separately.

	* doc/pdnsd.conf:
	Added CVS/RCS $Id$ tag.

	* cache.h, conf.l.templ, conf.y, conff.c, conff.h, config.h.templ, consts.h, dns.c, dns.h, dns_answer.c, dns_answer.h, dns_query.c, dns_query.h, error.c, error.h, exec-flex.sh, hash.c, hash.h, helpers.c, helpers.h, icmp.c, icmp.h, ipvers.h, main.c, netdev.c, netdev.h, pdnsd-redhat.spec.templ, pdnsd-suse.spec.templ, servers.c, servers.h, status.c, status.h, version, AUTHORS, INSTALL, Makefile, NEWS, README, THANKS, TODO, cache.c:
	Added CVS/RCS $Id$ tags to most files, did some cleanups, introduced
	the new rrset granularity caching. The new code is still much of beta,
	use with care.

2000-06-01  Thomas Moestl  <tmoestl@gmx.net>

	* Makefile, cache.c, hash.c, helpers.c, icmp.c, netdev.c:
	Yet another set of BSD fixes (test programs do now work for me
	under FreeBSD). Some other minor fixes.

	* Makefile, error.c, error.h, helpers.c, helpers.h:
	Transplanted kill_pdnsd from error.c to helpers.c in order to get the
	tests compiled without the thread library.

2000-05-31  Thomas Moestl  <tmoestl@gmx.net>

	* pdnsd:
	Ooops, executable got in.

	* Makefile, pdnsd:
	Added test suite programs.

	* icmp.c, netdev.c:
	All basic BSD patches have been folded in. pdnsd will now compile on
	FreeBSD with (hopefully) all features.

	* dns_answer.c, Makefile:
	Disabled udp targed address discovery for BSD builds (this sadly ist
	OS specific at least for IPv4. Must be rewritten under BSD as it is
	an RFC compatability issue under some circumstances)

	* cache.c, cache.h, conf.y, conff.c, conff.h, config.h.templ, dns_answer.c, helpers.c, icmp.c, ipvers.h, netdev.c, Makefile:
	BSD include & misc build fixes. More to follow...

	* Makefile, cache.h:
	BSD Fixes: Makefile should work with BSD make, sed command line,
	sorted out naming clash in cache.h

	* .cvsignore:
	Added ChangeLog to .cvsignore

	* THANKS, conff.c:
	Fixed a bug reported by Jonathan Hudson and added him to THANKS

	* ChangeLog.old:
	Added the pre-CVS ChangeLog.

	* .cvsignore, AUTHORS, COPYING, INSTALL, Makefile, NEWS, README, THANKS, TODO, cache.c, cache.h, conf.l.templ, conf.y, conff.c, conff.h, config.h.templ, consts.h, dns.c, dns.h, dns_answer.c, dns_answer.h, dns_query.c, dns_query.h, doc/.cvsignore, doc/html/dl.html, doc/html/doc.html, doc/html/faq.html, doc/html/index.html, doc/pdnsd.conf, doc/txt/.cvsignore, error.c, error.h, exec-flex.sh, hash.c, hash.h, helpers.c, helpers.h, icmp.c, icmp.h, ipvers.h, lex.inc.h, main.c, netdev.c, netdev.h, pdnsd-redhat.spec.templ, pdnsd-suse.spec.templ, servers.c, servers.h, status.c, status.h, version:
	Initial import of pdnsd-1.0.0p3 source tree into CVS.


	* .cvsignore, AUTHORS, COPYING, INSTALL, Makefile, NEWS, README, THANKS, TODO, cache.c, cache.h, conf.l.templ, conf.y, conff.c, conff.h, config.h.templ, consts.h, dns.c, dns.h, dns_answer.c, dns_answer.h, dns_query.c, dns_query.h, doc/.cvsignore, doc/html/dl.html, doc/html/doc.html, doc/html/faq.html, doc/html/index.html, doc/pdnsd.conf, doc/txt/.cvsignore, error.c, error.h, exec-flex.sh, hash.c, hash.h, helpers.c, helpers.h, icmp.c, icmp.h, ipvers.h, lex.inc.h, main.c, netdev.c, netdev.h, pdnsd-redhat.spec.templ, pdnsd-suse.spec.templ, servers.c, servers.h, status.c, status.h, version:
	New file.

